C++中的string類(C++字符串)入門完全攻略
前言
string 類是 STL 中 basic_string 模板實(shí)例化得到的模板類。其定義如下:
typedef basic_string <char> string;
basic_string 此處可以不必深究。
string 類的成員函數(shù)有很多,同一個(gè)名字的函數(shù)也常會(huì)有五六個(gè)重載的版本。篇幅所限,不能將這些原型一一列出并加以解釋。這里僅對(duì)常用成員函數(shù)按功能進(jìn)行分類,并直接給出應(yīng)用的例子,通過(guò)例子,讀者可以基本掌握這些成員函數(shù)的用法。
要想更深入地了解 string 類,還要閱讀 C++ 的參考手冊(cè)或編譯器自帶的聯(lián)機(jī)資料。對(duì)于前面介紹過(guò)的字符串處理的內(nèi)容,這里不再重復(fù)說(shuō)明。
1. 構(gòu)造函數(shù)
string 類有多個(gè)構(gòu)造函數(shù),用法示例如下:
string s1(); // si = "" string s2("Hello"); // s2 = "Hello" string s3(4, 'K'); // s3 = "KKKK" string s4("12345", 1, 3); //s4 = "234",即 "12345" 的從下標(biāo) 1 開始,長(zhǎng)度為 3 的子串
為稱呼方便,本教程后文將從字符串下標(biāo) n 開始、長(zhǎng)度為 m 的字符串稱為“子串(n, m)”。
string 類沒有接收一個(gè)整型參數(shù)或一個(gè)字符型參數(shù)的構(gòu)造函數(shù)。下面的兩種寫法是錯(cuò)誤的:
string s1('K'); string s2(123);
2. 對(duì) string 對(duì)象賦值
可以用 char* 類型的變量、常量,以及 char 類型的變量、常量對(duì) string 對(duì)象進(jìn)行賦值。例如:
string s1; s1 = "Hello"; // s1 = "Hello" s2 = 'K'; // s2 = "K”
string 類還有 assign 成員函數(shù),可以用來(lái)對(duì) string 對(duì)象賦值。assign 成員函數(shù)返回對(duì)象自身的引用。例如:
string s1("12345"), s2; s3.assign(s1); // s3 = s1 s2.assign(s1, 1, 2); // s2 = "23",即 s1 的子串(1, 2) s2.assign(4, 'K'); // s2 = "KKKK" s2.assign("abcde", 2, 3); // s2 = "cde",即 "abcde" 的子串(2, 3)
3. 求字符串的長(zhǎng)度
length 成員函數(shù)返回字符串的長(zhǎng)度。size 成員函數(shù)可以實(shí)現(xiàn)同樣的功能。
4. string對(duì)象中字符串的連接
除了可以使用+和+=運(yùn)算符對(duì) string 對(duì)象執(zhí)行字符串的連接操作外,string 類還有 append 成員函數(shù),可以用來(lái)向字符串后面添加內(nèi)容。append 成員函數(shù)返回對(duì)象自身的引用。例如:
string s1("123"), s2("abc"); s1.append(s2); // s1 = "123abc" s1.append(s2, 1, 2); // s1 = "123abcbc" s1.append(3, 'K'); // s1 = "123abcbcKKK" s1.append("ABCDE", 2, 3); // s1 = "123abcbcKKKCDE",添加 "ABCDE" 的子串(2, 3)
5. string對(duì)象的比較
除了可以用 <、<=、==、!=、>=、> 運(yùn)算符比較 string 對(duì)象外,string 類還有 compare 成員函數(shù),可用于比較字符串。
compare 成員函數(shù)有以下返回值:
- 小于 0 表示當(dāng)前的字符串??;
- 等于 0 表示兩個(gè)字符串相等;
- 大于 0 表示另一個(gè)字符串小。
例如:
string s1("hello"), s2("hello, world"); int n = s1.compare(s2); n = s1.compare(1, 2, s2, 0, 3); //比較s1的子串 (1,2) 和s2的子串 (0,3) n = s1.compare(0, 2, s2); // 比較s1的子串 (0,2) 和 s2 n = s1.compare("Hello"); n = s1.compare(1, 2, "Hello"); //比較 s1 的子串(1,2)和"Hello” n = s1.compare(1, 2, "Hello", 1, 2); //比較 s1 的子串(1,2)和 "Hello" 的子串(1,2)
6. 求 string 對(duì)象的子串
substr 成員函數(shù)可以用于求子串 (n, m),原型如下:
string substr(int n = 0, int m = string::npos) const;
調(diào)用時(shí),如果省略 m 或 m 超過(guò)了字符串的長(zhǎng)度,則求出來(lái)的子串就是從下標(biāo) n 開始一直到字符串結(jié)束的部分。例如:
string s1 = "this is ok"; string s2 = s1.substr(2, 4); // s2 = "is i" s2 = s1.substr(2); // s2 = "is is ok"
7. 交換兩個(gè)string對(duì)象的內(nèi)容
swap 成員函數(shù)可以交換兩個(gè) string 對(duì)象的內(nèi)容。例如:
string s1("West”), s2("East"); s1.swap(s2); // s1 = "East",s2 = "West"
8. 查找子串和字符
string 類有一些查找子串和字符的成員函數(shù),它們的返回值都是子串或字符在 string 對(duì)象字符串中的位置(即下標(biāo))。如果查不到,則返回 string::npos。string: :npos 是在 string 類中定義的一個(gè)靜態(tài)常量。這些函數(shù)如下:
- find:從前往后查找子串或字符出現(xiàn)的位置。
- rfind:從后往前查找子串或字符出現(xiàn)的位置。
- find_first_of:從前往后查找何處出現(xiàn)另一個(gè)字符串中包含的字符。例如:
- s1.find_first_of("abc"); //查找s1中第一次出現(xiàn)"abc"中任一字符的位置
- find_last_of:從后往前查找何處出現(xiàn)另一個(gè)字符串中包含的字符。
- find_first_not_of:從前往后查找何處出現(xiàn)另一個(gè)字符串中沒有包含的字符。
- find_last_not_of:從后往前查找何處出現(xiàn)另一個(gè)字符串中沒有包含的字符。
下面是 string 類的查找成員函數(shù)的示例程序。
#include <iostream> #include <string> using namespace std; int main() { string s1("Source Code"); int n; if ((n = s1.find('u')) != string::npos) //查找 u 出現(xiàn)的位置 cout << "1) " << n << "," << s1.substr(n) << endl; //輸出 l)2,urce Code if ((n = s1.find("Source", 3)) == string::npos) //從下標(biāo)3開始查找"Source",找不到 cout << "2) " << "Not Found" << endl; //輸出 2) Not Found if ((n = s1.find("Co")) != string::npos) //查找子串"Co"。能找到,返回"Co"的位置 cout << "3) " << n << ", " << s1.substr(n) << endl; //輸出 3) 7, Code if ((n = s1.find_first_of("ceo")) != string::npos) //查找第一次出現(xiàn)或 'c'、'e'或'o'的位置 cout << "4) " << n << ", " << s1.substr(n) << endl; //輸出 4) l, ource Code if ((n = s1.find_last_of('e')) != string::npos) //查找最后一個(gè) 'e' 的位置 cout << "5) " << n << ", " << s1.substr(n) << endl; //輸出 5) 10, e if ((n = s1.find_first_not_of("eou", 1)) != string::npos) //從下標(biāo)1開始查找第一次出現(xiàn)非 'e'、'o' 或 'u' 字符的位置 cout << "6) " << n << ", " << s1.substr(n) << endl; //輸出 6) 3, rce Code return 0; }
9. 替換子串
replace 成員函數(shù)可以對(duì) string 對(duì)象中的子串進(jìn)行替換,返回值為對(duì)象自身的引用。例如:
string s1("Real Steel"); s1.replace(1, 3, "123456", 2, 4); //用 "123456" 的子串(2,4) 替換 s1 的子串(1,3) cout << s1 << endl; //輸出 R3456 Steel string s2("Harry Potter"); s2.replace(2, 3, 5, '0'); //用 5 個(gè) '0' 替換子串(2,3) cout << s2 << endl; //輸出 HaOOOOO Potter int n = s2.find("OOOOO"); //查找子串 "00000" 的位置,n=2 s2.replace(n, 5, "XXX"); //將子串(n,5)替換為"XXX" cout << s2 < < endl; //輸出 HaXXX Potter
10. 刪除子串
erase 成員函數(shù)可以刪除 string 對(duì)象中的子串,返回值為對(duì)象自身的引用。例如:
string s1("Real Steel"); s1.erase(1, 3); //刪除子串(1, 3),此后 s1 = "R Steel" s1.erase(5); //刪除下標(biāo)5及其后面的所有字符,此后 s1 = "R Ste"
11. 插入字符串
insert 成員函數(shù)可以在 string 對(duì)象中插入另一個(gè)字符串,返回值為對(duì)象自身的引用。例如:
string s1("Limitless"), s2("00"); s1.insert(2, "123"); //在下標(biāo) 2 處插入字符串"123",s1 = "Li123mitless" s1.insert(3, s2); //在下標(biāo) 2 處插入 s2 , s1 = "Li10023mitless" s1.insert(3, 5, 'X'); //在下標(biāo) 3 處插入 5 個(gè) 'X',s1 = "Li1XXXXX0023mitless"
12. 將 string 對(duì)象作為流處理
使用流對(duì)象 istringstream 和 ostringstream,可以將 string 對(duì)象當(dāng)作一個(gè)流進(jìn)行輸入輸出。使用這兩個(gè)類需要包含頭文件 sstream。
示例程序如下:
#include <iostream> #include <sstream> #include <string> using namespace std; int main() { string src("Avatar 123 5.2 Titanic K"); istringstream istrStream(src); //建立src到istrStream的聯(lián)系 string s1, s2; int n; double d; char c; istrStream >> s1 >> n >> d >> s2 >> c; //把src的內(nèi)容當(dāng)做輸入流進(jìn)行讀取 ostringstream ostrStream; ostrStream << s1 << endl << s2 << endl << n << endl << d << endl << c <<endl; cout << ostrStream.str(); return 0; }
程序的輸出結(jié)果是:
Avatar
Titanic
123
5.2
K
第 11 行,從輸入流 istrStream 進(jìn)行讀取,過(guò)程和從 cin 讀取一樣,只不過(guò)輸入的來(lái)源由鍵盤變成了 string 對(duì)象 src。因此,"Avatar" 被讀取到 s1,123 被讀取到 n,5.2 被讀取到 d,"Titanic" 被讀取到s2,'K' 被讀取到 c。
第 12 行,將變量的值輸出到流 ostrStream。輸出結(jié)果不會(huì)出現(xiàn)在屏幕上,而是被保存在 ostrStream 對(duì)象管理的某處。用 ostringstream 類的 str 成員函數(shù)能將輸出到 ostringstream 對(duì)象中的內(nèi)容提取出來(lái)。
13. 用 STL 算法操作 string 對(duì)象
string 對(duì)象也可以看作一個(gè)順序容器,它支持隨機(jī)訪問(wèn)迭代器,也有 begin 和 end 等成員函數(shù)。STL 中的許多算法也適用于 string 對(duì)象。下面是用 STL 算法操作 string 對(duì)象的程序示例。
#include <iostream> #include <algorithm> #include <string> using namespace std; int main() { string s("afgcbed"); string::iterator p = find(s.begin(), s.end(), 'c'); if (p!= s.end()) cout << p - s.begin() << endl; //輸出 3 sort(s.begin(), s.end()); cout << s << endl; //輸出 abcdefg next_permutation(s.begin(), s.end()); cout << s << endl; //輸出 abcdegf return 0; }
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)我們的支持。
欄 目:C語(yǔ)言
下一篇:C語(yǔ)言實(shí)現(xiàn)QQ窗口抖動(dòng)功能
本文標(biāo)題:C++中的string類(C++字符串)入門完全攻略
本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/126.html
您可能感興趣的文章
- 04-02c語(yǔ)言沒有round函數(shù) round c語(yǔ)言
- 01-10深入理解C++中常見的關(guān)鍵字含義
- 01-10使用C++實(shí)現(xiàn)全排列算法的方法詳解
- 01-10深入Main函數(shù)中的參數(shù)argc,argv的使用詳解
- 01-10c++中inline的用法分析
- 01-10如何尋找數(shù)組中的第二大數(shù)
- 01-10用C++實(shí)現(xiàn)DBSCAN聚類算法
- 01-10全排列算法的非遞歸實(shí)現(xiàn)與遞歸實(shí)現(xiàn)的方法(C++)
- 01-10C++大數(shù)模板(推薦)
- 01-10淺談C/C++中的static與extern關(guān)鍵字的使用詳解


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 04-02c語(yǔ)言函數(shù)調(diào)用后清空內(nèi)存 c語(yǔ)言調(diào)用
- 04-02func函數(shù)+在C語(yǔ)言 func函數(shù)在c語(yǔ)言中
- 04-02c語(yǔ)言的正則匹配函數(shù) c語(yǔ)言正則表達(dá)
- 04-02c語(yǔ)言用函數(shù)寫分段 用c語(yǔ)言表示分段
- 04-02c語(yǔ)言中對(duì)數(shù)函數(shù)的表達(dá)式 c語(yǔ)言中對(duì)
- 04-02c語(yǔ)言編寫函數(shù)冒泡排序 c語(yǔ)言冒泡排
- 04-02c語(yǔ)言沒有round函數(shù) round c語(yǔ)言
- 04-02c語(yǔ)言分段函數(shù)怎么求 用c語(yǔ)言求分段
- 04-02C語(yǔ)言中怎么打出三角函數(shù) c語(yǔ)言中怎
- 04-02c語(yǔ)言調(diào)用函數(shù)求fibo C語(yǔ)言調(diào)用函數(shù)求
隨機(jī)閱讀
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-10delphi制作wav文件的方法
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 04-02jquery與jsp,用jquery
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10C#中split用法實(shí)例總結(jié)