- string類對象和C風(fēng)格的字符數(shù)組最大的區(qū)別就是誉帅,字符數(shù)組的長度必須指定或定義時由初始化確定咱揍,而string類對象的字符串長度時可以動態(tài)改變,不限制長度的需五。而且护桦,因?yàn)槭穷悓ο罄认埽钥梢杂煤芏囝惓蓡T函數(shù),也可以自己擴(kuò)展可用的類成員函數(shù)懈玻。
函數(shù)名 描述
begin ——得到指向字符串開頭的Iterator
end ——得到指向字符串結(jié)尾的Iterator
rbegin ——得到指向反向字符串開頭的Iterator
rend ——得到指向反向字符串結(jié)尾的Iterator
push_back(str) ——追加一個字符巧婶,不能追加字符串,此函數(shù)來自容器
assign(str) ——和賦值操作符一樣涂乌,此函數(shù)來自容器
size ——得到字符串的大小
length ——和size函數(shù)功能相同
max_size ——字符串可能的最大大小艺栈。空間足夠多就足夠大
capacity ——在不重新分配內(nèi)存的情況下骂倘,字符串最大可能的大小眼滤,
——————每次分配的內(nèi)存用完時增加原長的1/2
empty ——判斷是否為空
operator[] ——取第幾個元素,相當(dāng)于數(shù)組
c_str ——取得C風(fēng)格的const char* 字符串
data ——取得C風(fēng)格的const char* 字符串历涝,同上
operator= ——賦值操作符
reserve ——預(yù)留空間诅需,參數(shù)是字節(jié)數(shù)漾唉,若預(yù)留足夠多,可不必在一些增刪改操作時——————重新分配內(nèi)存而導(dǎo)致一些指針地址失效
swap(str) ——交換函數(shù)堰塌,參數(shù)也一定是個string對象赵刑,不能是常量字符串
insert(pos1, str, pos2=0, len=str.lenth()) ——插入字符到指定位置,有多個用法
append(str, pos, len) ——追加字符串场刑,若不提供pos和len般此,則和 +=操作一樣
operator+= ——+= 操作符,追加字符串牵现,同上簡單使用
erase(pos, len) ——刪除字符串
clear() ——清空字符容器中所有內(nèi)容
resize() ——重新分配空間
replace(pos1, len1, str2, pos2, len2) ——替代字符串铐懊,可用erase()和insert()函數(shù)組合實(shí)現(xiàn)。借助find和循環(huán)瞎疼,可實(shí)現(xiàn)替換字符串中某些詞
copy(str, len) ——復(fù)制字符串len個字符到str的空間科乎,要確保空間足夠贼急,否則報錯
substr(begin, len) ——得到子串茅茂,返回從begin(默認(rèn)0)開始長為len的子串,默認(rèn)len為到末尾
compare(pos1, len1, string2, pos2, len2) ——比較字符串太抓,和strcmp類似空闲,返回0為相等,1大于走敌,-1小于碴倾。還可以子串指定和另一字符串的第幾個字符開始的一個子串進(jìn)行比較
operator+ ——字符串鏈接
operator== ——判斷字符串是否相等
operator!= ——判斷是否不等于
operator< ——判斷是否小于
operator<< ——字符串寫入輸出流,cout<<str<<endl;
operator>> ——從輸入流中讀入字符串掉丽,cin>> str;
getline(cin, str) ——從輸入流中讀入一行到string對象影斑,不限制長度。cin.getline(cstr, len)必須讀取指定長度的字符到指定大小的字符數(shù)組机打。
-
常用的查找函數(shù),查找成功時返回首字符所在的順位置片迅,失敗返回std::string::npos的值4294967295=2^32-1残邀,即int型32位數(shù)字最大值
int find(char c, int pos = 0) const;//從pos開始查找字符c在當(dāng)前字符串的位置
int find(const char *s, int pos = 0) const;//從pos開始查找字符串s在當(dāng)前串中的位置
int find(const char *s, int pos, int n) const;//從pos開始查找字符串s中前n個字符在當(dāng)前串中的位置
int find(const string &s, int pos = 0) const;//從pos開始查找字符串s在當(dāng)前串中的位置
int rfind(char c, int pos = npos) const;//從pos開始從后向前查找字符c在當(dāng)前串中的位置
int rfind(const char *s, int pos = npos) const;//從pos+strlen(s)-1開始從后向前查找字符c在當(dāng)前串中的位置
int rfind(const char *s, int pos, int n = npos) const;
int rfind(const string &s,int pos = npos) const;
——————
find_first_of ——查找包含子串中的任何一個字符,返回第一個位置
find_first_not_of ——查找不包含子串中的任何字符柑蛇,返回第一個位置
find_last_of ——查找包含子串中的任何字符芥挣,返回最后一個位置
find_last_not_of ——查找不包含子串中的任何字符,返回最后一個位置
string和數(shù)值轉(zhuǎn)換
to_string(val) ——把val轉(zhuǎn)換成string
stoi(s,p,b) ——把字符串s從p開始轉(zhuǎn)換成b進(jìn)制的int耻台,p默認(rèn)為0空免,b默認(rèn)10,下同
stol(s,p,b) ——long
stoul(s,p,b) ——unsigned long
stoll(s,p,b) ——long long
stoull(s,p,b) ——unsigned long long
stof(s,p) ——float
stod(s,p) ——double
stold(s,p) ——long double
- 此博客中有多個函數(shù)的多種用法舉例:https://blog.csdn.net/tengfei461807914/article/details/52203202