C++中string類的常用方法實(shí)例總結(jié)
引言
C++中提供了一種新的數(shù)據(jù)類型——字符串類型(string)。實(shí)際上string并不是C++的基本類型,它是在C++標(biāo)準(zhǔn)庫(kù)中聲明的一個(gè)字符串類,用這種數(shù)據(jù)類型可以定義對(duì)象,每一個(gè)字符串變量都是string類的一個(gè)對(duì)象。標(biāo)準(zhǔn)庫(kù)類型string表示可變長(zhǎng)的字符序列,使用string類型必須首先包含它的頭文件。
作為標(biāo)準(zhǔn)庫(kù)的一部分,string定義在命名空間std中。
【例】
#include<string>//注意這里沒(méi)有.h using namespace std;
string類的意義有兩個(gè):第一個(gè)是為了處理char類型的數(shù)組,并封裝了標(biāo)準(zhǔn)C中的一些字符串處理的函數(shù)。而當(dāng)string類進(jìn)入了C++標(biāo)準(zhǔn)后,它的第二個(gè)意義就是一個(gè)容器。
C++ string類常用方法
1、string(const char *s) :將 string 對(duì)象初始化為 s 指向的字符串
string str("hello");
2、string(size_type n,char c) :創(chuàng)建一個(gè)包含 n 個(gè)元素的 string 對(duì)象,其中每個(gè)元素都被初始化為字符 c
string str(10, 'a');
3、string(const string &str) :將一個(gè) string 對(duì)象初始化為 string 對(duì)象 str(復(fù)制構(gòu)造函數(shù))
string str("abcde"); string str2(str);
4、string() :創(chuàng)建一個(gè)默認(rèn)的 string 對(duì)象,長(zhǎng)度為 0(默認(rèn)構(gòu)造函數(shù))
string str;
5、使用C語(yǔ)言風(fēng)格字符串處理string對(duì)象
string str = "hello!";
6、獲取string對(duì)象的長(zhǎng)度,C語(yǔ)言中使用strlen()來(lái)獲取字符串長(zhǎng)度,C++中使用str.size()或str.length().
string str("hello!"); int len1 = str.size(); int len2 = str.length();
7、將一個(gè) string 對(duì)象賦值給另一個(gè) string 對(duì)象
string str("hello!"); string str2; str2 = str;
8、string 對(duì)象的拼接
C 語(yǔ)言中使用 strcat、strncat 函數(shù)來(lái)進(jìn)行字符串拼接操作,C++中可以采用以下方式:
string str1("hello"); string str2("world"); string str3 = str1 + str2;
9、使用 += 來(lái)在一個(gè) string 對(duì)象后面附加一個(gè) string 對(duì)象、字符以及 C 風(fēng)格的字符串
string str("hello"); string str2("world"); str += str2; str += 'a'; str += "abcd";
10、string.append() 函數(shù),在string對(duì)象后添加一個(gè)string對(duì)象或c風(fēng)格字符串。
string str("hello"); string str2("world"); str.append(str2); str.append("abcd");
11、string.push_back() 函數(shù)來(lái)在一個(gè) string 對(duì)象后面附加一個(gè)字符
string str("hello"); char ch = 'a'; str.push_back(ch);
12、對(duì)于string對(duì)象的比較,可以直接使用關(guān)系運(yùn)算符。
string str1("abcd"); string str2("abcd"); if(str1 == str2) break;
13、string對(duì)象的比較也可以使用string.compare() 方法
int compare(const string&str) const; int compare(size_t pos,size_t len,const string&str)const; int compare(size_t pos,size_t len,const string&str, size_t subpos,size_t sublen)const; int compare(const char * s)const; int compare(size_t pos,size_t len,const char * s)const; int compare(size_t pos,size_t len,const char * s,size_t n)const; // example string str1("hello world"); string str2("hello boy"); str1.compare(6, 3, str2, 6, 3);
14、使用 string.substr() 函數(shù)來(lái)獲取子串
string str("hello"); string str2 = str.substr(3,2)
15、訪問(wèn) string 字符串的元素
string str("hello"); cout << str[2] << endl; cout << str.at(2) << endl;
16、使用 string.find() 方法查找字符
// 從字符串的 pos 位置開(kāi)始(若不指定 pos 的值,則默認(rèn)從索引 0 處開(kāi)始),查找子字符串 str。 // 如果找到,則返回該子字符串首次出現(xiàn)時(shí)其首字符的索引;否則,返回 string::npos: // string 類將 npos 定義為保證大于任何有效下標(biāo)的值。 size_type find (const string& str, size_type pos = 0) const; size_type find (const char *s, size_type pos = 0) const; size_type find (const char *s, size_type pos, size_type n); size_type find (char ch, size_type pos = 0) const;
17、string.rfind() 與 string.find() 方法類似,只是查找順序不一樣, string.rfind() 是從指定位置 pos (默認(rèn)為字符串末尾)開(kāi)始向前查找,直到字符串的首部,并返回第一次查找到匹配項(xiàng)時(shí)匹配項(xiàng)首字符的索引。換句話說(shuō),就是查找子字符串或字符最后一次出現(xiàn)的位置。
18、string.find_first_of() 方法在字符串中從指定位置開(kāi)始向后(默認(rèn)為索引 0 處)查找參數(shù)中任何一個(gè)字符首次出現(xiàn)的位置
string str("hello world"); int pos = str.find_first_of("abcde"); int pos = str.find_first_of("abcde", 1); // 第二個(gè)參數(shù)為位置
19、string.find_last_of() 方法在字符串中查找參數(shù)中任何一個(gè)字符最后一次出現(xiàn)的位置
20、string.find_first_not_of() 方法在字符串中查找第一個(gè)不包含在參數(shù)中的字符
21、string.find_last_not_of() 方法在字符串中查找最后一個(gè)不包含在參數(shù)中的字符
22、使用 string.insert() 進(jìn)行插入操作
string& insert(size_t pos,const string&str); // 在位置 pos 處插入字符串 str string& insert(size_t pos,const string&str,size_t subpos,size_t sublen); // 在位置 pos 處插入字符串 str 的從位置 subpos 處開(kāi)始的 sublen 個(gè)字符 string& insert(size_t pos,const char * s); // 在位置 pos 處插入字符串 s string& insert(size_t pos,const char * s,size_t n); // 在位置 pos 處插入字符串 s 的前 n 個(gè)字符 string& insert(size_t pos,size_t n,char c); // 在位置 pos 處插入 n 個(gè)字符 c iterator insert (const_iterator p, size_t n, char c); // 在 p 處插入 n 個(gè)字符 c,并返回插入后迭代器的位置 iterator insert (const_iterator p, char c); // 在 p 處插入字符 c,并返回插入后迭代器的位置
23、使用 string.erase() 進(jìn)行元素刪除操作
string& erase (size_t pos = 0, size_t len = npos); // 刪除從 pos 處開(kāi)始的 n 個(gè)字符 iterator erase (const_iterator p); // 刪除 p 處的一個(gè)字符,并返回刪除后迭代器的位置 iterator erase (const_iterator first, const_iterator last); // 刪除從 first 到last 之間的字符,并返回刪除后迭代器的位置
24、使用 getline() 函數(shù)來(lái)獲取 string 輸入
string str; getline(cin, str);
25、使用 string.empty() 函數(shù)判斷字符串是否為空
26、使用 string.swap() 函數(shù)交換兩個(gè)字符串
string str1 = "hello"; string str2 = "HELLO"; str1.swap(str2);
27、string.back()獲取或修改字符串最后一個(gè)字符
string str("abcd"); char b = str.back(); str.back() = 'e';
28、string.front()獲取或修改字符串第一個(gè)字符
29、string.pop_back()刪除字符串最后一個(gè)元素
總結(jié)
到此這篇關(guān)于C++中string類的常用方法的文章就介紹到這了,更多相關(guān)C++ string類常用方法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++實(shí)現(xiàn)LeetCode(53.最大子數(shù)組)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(53.最大子數(shù)組),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07Java?C++?算法題解leetcode652尋找重復(fù)子樹(shù)
這篇文章主要為大家介紹了Java?C++?算法題解leetcode652尋找重復(fù)子樹(shù)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09c語(yǔ)言獲取當(dāng)前工作路徑的實(shí)現(xiàn)代碼(windows/linux)
這篇文章主要介紹了c語(yǔ)言獲取當(dāng)前工作路徑的實(shí)現(xiàn)代碼(windows/linux),需要的朋友可以參考下2017-09-09C語(yǔ)言錯(cuò)誤信息報(bào)告strerror函數(shù)和perror函數(shù)詳解
這篇文章主要介紹了C語(yǔ)言錯(cuò)誤信息報(bào)告strerror函數(shù)和perror函數(shù),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-03-03基于C語(yǔ)言實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng)
這篇文章主要介紹了基于C語(yǔ)言實(shí)現(xiàn)學(xué)生成績(jī)管理系統(tǒng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01淺理解C++ 人臉識(shí)別系統(tǒng)的實(shí)現(xiàn)
這篇文章主要介紹了淺理解C++ 人臉識(shí)別系統(tǒng)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03C++實(shí)現(xiàn)模擬shell命令行(代碼解析)
這篇文章主要介紹了C++實(shí)現(xiàn)模擬shell命令行,本文通過(guò)實(shí)例代碼進(jìn)行命令行解析,代碼簡(jiǎn)單易懂,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-12-12C++二叉樹(shù)結(jié)構(gòu)的建立與基本操作
二叉樹(shù)是數(shù)據(jù)結(jié)構(gòu)中的樹(shù)的一種特殊情況,有關(guān)二叉樹(shù)的相關(guān)概念,這里不再贅述,如果不了解二叉樹(shù)相關(guān)概念,建議先學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)中的二叉樹(shù)的知識(shí)點(diǎn)2013-10-10