国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C++ > 正文

C++中的string類(C++字符串)入門完全攻略

2020-01-26 11:44:41
字體:
供稿:網(wǎng)友

前言

string 類是 STL 中 basic_string 模板實例化得到的模板類。其定義如下:

typedef basic_string <char> string;

basic_string 此處可以不必深究。

string 類的成員函數(shù)有很多,同一個名字的函數(shù)也常會有五六個重載的版本。篇幅所限,不能將這些原型一一列出并加以解釋。這里僅對常用成員函數(shù)按功能進行分類,并直接給出應(yīng)用的例子,通過例子,讀者可以基本掌握這些成員函數(shù)的用法。

要想更深入地了解 string 類,還要閱讀 C++ 的參考手冊或編譯器自帶的聯(lián)機資料。對于前面介紹過的字符串處理的內(nèi)容,這里不再重復說明。

1. 構(gòu)造函數(shù)

string 類有多個構(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" 的從下標 1 開始,長度為 3 的子串

為稱呼方便,本教程后文將從字符串下標 n 開始、長度為 m 的字符串稱為“子串(n, m)”。

string 類沒有接收一個整型參數(shù)或一個字符型參數(shù)的構(gòu)造函數(shù)。下面的兩種寫法是錯誤的:

string s1('K');string s2(123);

2. 對 string 對象賦值

可以用 char* 類型的變量、常量,以及 char 類型的變量、常量對 string 對象進行賦值。例如:

string s1;s1 = "Hello"; // s1 = "Hello"s2 = 'K'; // s2 = "K”

string 類還有 assign 成員函數(shù),可以用來對 string 對象賦值。assign 成員函數(shù)返回對象自身的引用。例如:

string s1("12345"), s2;s3.assign(s1); // s3 = s1s2.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. 求字符串的長度

length 成員函數(shù)返回字符串的長度。size 成員函數(shù)可以實現(xiàn)同樣的功能。

4. string對象中字符串的連接

除了可以使用+和+=運算符對 string 對象執(zhí)行字符串的連接操作外,string 類還有 append 成員函數(shù),可以用來向字符串后面添加內(nèi)容。append 成員函數(shù)返回對象自身的引用。例如:

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對象的比較

除了可以用 <、<=、==、!=、>=、> 運算符比較 string 對象外,string 類還有 compare 成員函數(shù),可用于比較字符串。

compare 成員函數(shù)有以下返回值:

  • 小于 0 表示當前的字符串小;
  • 等于 0 表示兩個字符串相等;
  • 大于 0 表示另一個字符串小。

例如:

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) 和 s2n = 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 對象的子串

substr 成員函數(shù)可以用于求子串 (n, m),原型如下:

string substr(int n = 0, int m = string::npos) const;

調(diào)用時,如果省略 m 或 m 超過了字符串的長度,則求出來的子串就是從下標 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. 交換兩個string對象的內(nèi)容
swap 成員函數(shù)可以交換兩個 string 對象的內(nèi)容。例如:

string s1("West”), s2("East");s1.swap(s2); // s1 = "East",s2 = "West"

8. 查找子串和字符

string 類有一些查找子串和字符的成員函數(shù),它們的返回值都是子串或字符在 string 對象字符串中的位置(即下標)。如果查不到,則返回 string::npos。string: :npos 是在 string 類中定義的一個靜態(tài)常量。這些函數(shù)如下:

  • find:從前往后查找子串或字符出現(xiàn)的位置。
  • rfind:從后往前查找子串或字符出現(xiàn)的位置。
  • find_first_of:從前往后查找何處出現(xiàn)另一個字符串中包含的字符。例如:
  • s1.find_first_of("abc");  //查找s1中第一次出現(xiàn)"abc"中任一字符的位置
  • find_last_of:從后往前查找何處出現(xiàn)另一個字符串中包含的字符。
  • find_first_not_of:從前往后查找何處出現(xiàn)另一個字符串中沒有包含的字符。
  • find_last_not_of:從后往前查找何處出現(xiàn)另一個字符串中沒有包含的字符。

下面是 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)  //從下標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)  //查找最后一個 'e' 的位置  cout << "5) " << n << ", " << s1.substr(n) << endl; //輸出 5) 10, e if ((n = s1.find_first_not_of("eou", 1)) != string::npos)  //從下標1開始查找第一次出現(xiàn)非 'e'、'o' 或 'u' 字符的位置  cout << "6) " << n << ", " << s1.substr(n) << endl; //輸出 6) 3, rce Code return 0;}

9. 替換子串

replace 成員函數(shù)可以對 string 對象中的子串進行替換,返回值為對象自身的引用。例如:

string s1("Real Steel");s1.replace(1, 3, "123456", 2, 4); //用 "123456" 的子串(2,4) 替換 s1 的子串(1,3)cout << s1 << endl; //輸出 R3456 Steelstring s2("Harry Potter");s2.replace(2, 3, 5, '0'); //用 5 個 '0' 替換子串(2,3)cout << s2 << endl; //輸出 HaOOOOO Potterint n = s2.find("OOOOO"); //查找子串 "00000" 的位置,n=2s2.replace(n, 5, "XXX"); //將子串(n,5)替換為"XXX"cout << s2 < < endl; //輸出 HaXXX Potter

10. 刪除子串

erase 成員函數(shù)可以刪除 string 對象中的子串,返回值為對象自身的引用。例如:

string s1("Real Steel");s1.erase(1, 3); //刪除子串(1, 3),此后 s1 = "R Steel"s1.erase(5); //刪除下標5及其后面的所有字符,此后 s1 = "R Ste"

11. 插入字符串

insert 成員函數(shù)可以在 string 對象中插入另一個字符串,返回值為對象自身的引用。例如:

string s1("Limitless"), s2("00");s1.insert(2, "123"); //在下標 2 處插入字符串"123",s1 = "Li123mitless"s1.insert(3, s2); //在下標 2 處插入 s2 , s1 = "Li10023mitless"s1.insert(3, 5, 'X'); //在下標 3 處插入 5 個 'X',s1 = "Li1XXXXX0023mitless"

12. 將 string 對象作為流處理

使用流對象 istringstream 和 ostringstream,可以將 string 對象當作一個流進行輸入輸出。使用這兩個類需要包含頭文件 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)容當做輸入流進行讀取  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 進行讀取,過程和從 cin 讀取一樣,只不過輸入的來源由鍵盤變成了 string 對象 src。因此,"Avatar" 被讀取到 s1,123 被讀取到 n,5.2 被讀取到 d,"Titanic" 被讀取到s2,'K' 被讀取到 c。

第 12 行,將變量的值輸出到流 ostrStream。輸出結(jié)果不會出現(xiàn)在屏幕上,而是被保存在 ostrStream 對象管理的某處。用 ostringstream 類的 str 成員函數(shù)能將輸出到 ostringstream 對象中的內(nèi)容提取出來。

13. 用 STL 算法操作 string 對象

string 對象也可以看作一個順序容器,它支持隨機訪問迭代器,也有 begin 和 end 等成員函數(shù)。STL 中的許多算法也適用于 string 對象。下面是用 STL 算法操作 string 對象的程序示例。

#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é)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對武林網(wǎng)的支持。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 福州市| 衡南县| 上杭县| 化德县| 河池市| 台前县| 东阳市| 富阳市| 开封市| 乐陵市| 留坝县| 日喀则市| 宕昌县| 渝中区| 新龙县| 丽江市| 蕲春县| 鄂尔多斯市| 北流市| 龙江县| 汉寿县| 乌拉特中旗| 瑞丽市| 洮南市| 宁陵县| 富宁县| 来宾市| 武冈市| 兴国县| 卢龙县| 商南县| 长垣县| 蒙城县| 怀远县| 常山县| 九龙县| 綦江县| 区。| 海安县| 鄂尔多斯市| 习水县|