- string類對象和C風(fēng)格的字符數(shù)組最大的區(qū)別就是,字符數(shù)組的長度必須指定或定義時(shí)由初始化確定,而string類對象的字符串長度時(shí)可以動(dòng)態(tài)改變,不限制長度的。而且,因?yàn)槭穷悓ο?,所以可以用很多類成員函數(shù),也可以自己擴(kuò)展可用的類成員函數(shù)。
函數(shù)名 描述
begin ——得到指向字符串開頭的Iterator
end ——得到指向字符串結(jié)尾的Iterator
rbegin ——得到指向反向字符串開頭的Iterator
rend ——得到指向反向字符串結(jié)尾的Iterator
push_back(str) ——追加一個(gè)字符,不能追加字符串,此函數(shù)來自容器
assign(str) ——和賦值操作符一樣,此函數(shù)來自容器
size ——得到字符串的大小
length ——和size函數(shù)功能相同
max_size ——字符串可能的最大大小??臻g足夠多就足夠大
capacity ——在不重新分配內(nèi)存的情況下,字符串最大可能的大小,
——————每次分配的內(nèi)存用完時(shí)增加原長的1/2
empty ——判斷是否為空
operator[] ——取第幾個(gè)元素,相當(dāng)于數(shù)組
c_str ——取得C風(fēng)格的const char* 字符串
data ——取得C風(fēng)格的const char* 字符串,同上
operator= ——賦值操作符
reserve ——預(yù)留空間,參數(shù)是字節(jié)數(shù),若預(yù)留足夠多,可不必在一些增刪改操作時(shí)——————重新分配內(nèi)存而導(dǎo)致一些指針地址失效
swap(str) ——交換函數(shù),參數(shù)也一定是個(gè)string對象,不能是常量字符串
insert(pos1, str, pos2=0, len=str.lenth()) ——插入字符到指定位置,有多個(gè)用法
append(str, pos, len) ——追加字符串,若不提供pos和len,則和 +=操作一樣
operator+= ——+= 操作符,追加字符串,同上簡單使用
erase(pos, len) ——?jiǎng)h除字符串
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個(gè)字符到str的空間,要確??臻g足夠,否則報(bào)錯(cuò)
substr(begin, len) ——得到子串,返回從begin(默認(rèn)0)開始長為len的子串,默認(rèn)len為到末尾
compare(pos1, len1, string2, pos2, len2) ——比較字符串,和strcmp類似,返回0為相等,1大于,-1小于。還可以子串指定和另一字符串的第幾個(gè)字符開始的一個(gè)子串進(jìn)行比較
operator+ ——字符串鏈接
operator== ——判斷字符串是否相等
operator!= ——判斷是否不等于
operator< ——判斷是否小于
operator<< ——字符串寫入輸出流,cout<<str<<endl;
operator>> ——從輸入流中讀入字符串,cin>> str;
getline(cin, str) ——從輸入流中讀入一行到string對象,不限制長度。cin.getline(cstr, len)必須讀取指定長度的字符到指定大小的字符數(shù)組。
-
常用的查找函數(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個(gè)字符在當(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 ——查找包含子串中的任何一個(gè)字符,返回第一個(gè)位置
find_first_not_of ——查找不包含子串中的任何字符,返回第一個(gè)位置
find_last_of ——查找包含子串中的任何字符,返回最后一個(gè)位置
find_last_not_of ——查找不包含子串中的任何字符,返回最后一個(gè)位置
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
- 此博客中有多個(gè)函數(shù)的多種用法舉例:https://blog.csdn.net/tengfei461807914/article/details/52203202