亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++中string類的常用方法實例總結

 更新時間:2022年03月16日 10:45:00   作者:Goallegoal  
string類是C++提供的抽象數(shù)據(jù)類型,其支持可變長字符串,下面這篇文章主要給大家總結介紹了關于C++中string類的常用方法,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下

引言

C++中提供了一種新的數(shù)據(jù)類型——字符串類型(string)。實際上string并不是C++的基本類型,它是在C++標準庫中聲明的一個字符串類,用這種數(shù)據(jù)類型可以定義對象,每一個字符串變量都是string類的一個對象。標準庫類型string表示可變長的字符序列,使用string類型必須首先包含它的頭文件。

作為標準庫的一部分,string定義在命名空間std中。

【例】

#include<string>//注意這里沒有.h 
using namespace std;

string類的意義有兩個:第一個是為了處理char類型的數(shù)組,并封裝了標準C中的一些字符串處理的函數(shù)。而當string類進入了C++標準后,它的第二個意義就是一個容器。

C++ string類常用方法

1、string(const char *s) :將 string 對象初始化為 s 指向的字符串

string str("hello");

2、string(size_type n,char c) :創(chuàng)建一個包含 n 個元素的 string 對象,其中每個元素都被初始化為字符 c

string str(10, 'a');

3、string(const string &str) :將一個 string 對象初始化為 string 對象 str(復制構造函數(shù))

string str("abcde");
string str2(str);

4、string() :創(chuàng)建一個默認的 string 對象,長度為 0(默認構造函數(shù))

string str;

5、使用C語言風格字符串處理string對象

string str = "hello!";

6、獲取string對象的長度,C語言中使用strlen()來獲取字符串長度,C++中使用str.size()或str.length().

string str("hello!");
int len1 = str.size();
int len2 = str.length();

7、將一個 string 對象賦值給另一個 string 對象

string str("hello!");
string str2;
str2 = str;

8、string 對象的拼接

C 語言中使用 strcat、strncat 函數(shù)來進行字符串拼接操作,C++中可以采用以下方式:

string str1("hello");
string str2("world");
string str3 = str1 + str2;

9、使用 += 來在一個 string 對象后面附加一個 string 對象、字符以及 C 風格的字符串

string str("hello");
string str2("world");
str += str2;
str += 'a';
str += "abcd";

10、string.append() 函數(shù),在string對象后添加一個string對象或c風格字符串。

string str("hello");
string str2("world");
str.append(str2);
str.append("abcd");

11、string.push_back() 函數(shù)來在一個 string 對象后面附加一個字符

string str("hello");
char ch = 'a';
str.push_back(ch);

12、對于string對象的比較,可以直接使用關系運算符。

string str1("abcd");
string str2("abcd");
if(str1 == str2)
    break;

13、string對象的比較也可以使用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ù)來獲取子串

string str("hello");
string str2 = str.substr(3,2)

15、訪問 string 字符串的元素

string str("hello");
cout << str[2] << endl;
cout << str.at(2) << endl;

16、使用 string.find() 方法查找字符

//  從字符串的 pos 位置開始(若不指定 pos 的值,則默認從索引 0 處開始),查找子字符串 str。
//  如果找到,則返回該子字符串首次出現(xiàn)時其首字符的索引;否則,返回 string::npos:
//  string 類將 npos 定義為保證大于任何有效下標的值。
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 (默認為字符串末尾)開始向前查找,直到字符串的首部,并返回第一次查找到匹配項時匹配項首字符的索引。換句話說,就是查找子字符串或字符最后一次出現(xiàn)的位置。

18、string.find_first_of() 方法在字符串中從指定位置開始向后(默認為索引 0 處)查找參數(shù)中任何一個字符首次出現(xiàn)的位置

string str("hello world");
int pos = str.find_first_of("abcde");
int pos = str.find_first_of("abcde", 1);  // 第二個參數(shù)為位置

19、string.find_last_of() 方法在字符串中查找參數(shù)中任何一個字符最后一次出現(xiàn)的位置

20、string.find_first_not_of() 方法在字符串中查找第一個不包含在參數(shù)中的字符

21、string.find_last_not_of() 方法在字符串中查找最后一個不包含在參數(shù)中的字符

22、使用 string.insert() 進行插入操作

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 處開始的 sublen 個字符

string& insert(size_t pos,const char * s);    
// 在位置 pos 處插入字符串 s

string& insert(size_t pos,const char * s,size_t n); 
// 在位置 pos 處插入字符串 s 的前 n 個字符

string& insert(size_t pos,size_t n,char c);      
// 在位置 pos 處插入 n 個字符 c

iterator insert (const_iterator p, size_t n, char c); 
// 在 p 處插入 n 個字符 c,并返回插入后迭代器的位置

iterator insert (const_iterator p, char c);       
// 在 p 處插入字符 c,并返回插入后迭代器的位置

23、使用 string.erase() 進行元素刪除操作

string& erase (size_t pos = 0, size_t len = npos);   // 刪除從 pos 處開始的 n 個字符
iterator erase (const_iterator p);            // 刪除 p 處的一個字符,并返回刪除后迭代器的位置
iterator erase (const_iterator first, const_iterator last); // 刪除從 first 到last 之間的字符,并返回刪除后迭代器的位置

24、使用 getline() 函數(shù)來獲取 string 輸入

string str;
getline(cin, str);

25、使用 string.empty() 函數(shù)判斷字符串是否為空

26、使用 string.swap() 函數(shù)交換兩個字符串

string str1 = "hello";
string str2 = "HELLO";
str1.swap(str2);

27、string.back()獲取或修改字符串最后一個字符

string str("abcd");
char b = str.back();
str.back() = 'e';

28、string.front()獲取或修改字符串第一個字符

29、string.pop_back()刪除字符串最后一個元素

總結

到此這篇關于C++中string類的常用方法的文章就介紹到這了,更多相關C++ string類常用方法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • C++實現(xiàn)LeetCode(53.最大子數(shù)組)

    C++實現(xiàn)LeetCode(53.最大子數(shù)組)

    這篇文章主要介紹了C++實現(xiàn)LeetCode(53.最大子數(shù)組),本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • Java?C++?算法題解leetcode652尋找重復子樹

    Java?C++?算法題解leetcode652尋找重復子樹

    這篇文章主要為大家介紹了Java?C++?算法題解leetcode652尋找重復子樹示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • C++中指針函數(shù)與函數(shù)指針的使用

    C++中指針函數(shù)與函數(shù)指針的使用

    今天小編就為大家分享一篇關于C++中指針函數(shù)與函數(shù)指針的使用,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-12-12
  • c語言獲取當前工作路徑的實現(xiàn)代碼(windows/linux)

    c語言獲取當前工作路徑的實現(xiàn)代碼(windows/linux)

    這篇文章主要介紹了c語言獲取當前工作路徑的實現(xiàn)代碼(windows/linux),需要的朋友可以參考下
    2017-09-09
  • C語言錯誤信息報告strerror函數(shù)和perror函數(shù)詳解

    C語言錯誤信息報告strerror函數(shù)和perror函數(shù)詳解

    這篇文章主要介紹了C語言錯誤信息報告strerror函數(shù)和perror函數(shù),本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-03-03
  • 基于C語言實現(xiàn)學生成績管理系統(tǒng)

    基于C語言實現(xiàn)學生成績管理系統(tǒng)

    這篇文章主要介紹了基于C語言實現(xiàn)學生成績管理系統(tǒng),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • 淺理解C++ 人臉識別系統(tǒng)的實現(xiàn)

    淺理解C++ 人臉識別系統(tǒng)的實現(xiàn)

    這篇文章主要介紹了淺理解C++ 人臉識別系統(tǒng)的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-03-03
  • C++實現(xiàn)模擬shell命令行(代碼解析)

    C++實現(xiàn)模擬shell命令行(代碼解析)

    這篇文章主要介紹了C++實現(xiàn)模擬shell命令行,本文通過實例代碼進行命令行解析,代碼簡單易懂,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-12-12
  • C++中const的用法詳細總結

    C++中const的用法詳細總結

    以下是對C++中const的用法進行了詳細的總結分析,需要的朋友可以過來參考下,希望對大家有所幫助
    2013-09-09
  • C++二叉樹結構的建立與基本操作

    C++二叉樹結構的建立與基本操作

    二叉樹是數(shù)據(jù)結構中的樹的一種特殊情況,有關二叉樹的相關概念,這里不再贅述,如果不了解二叉樹相關概念,建議先學習數(shù)據(jù)結構中的二叉樹的知識點
    2013-10-10

最新評論