标准c++中String类非常强大,合理使用,能极大提高编程效率,下面就对string类的用法进行总结。
头文件
#include<string>
1) string s; //生成一个空字符串s
2) string s(str) //拷贝构造函数生成str的复制品
3) string s(str,index) //将字符串str内“始于位置index”的部分当作字符串的初值
4) string s(str,index, n) //将字符串str内“始于index且长度顶多n”的部分作为字符串的初值
5) string s(cstr) //将C字符串作为s的初值
6) string s(chars,chars_len) //将C字符串前chars_len个字符作为字符串s的初值。
7) string s(n,c) //生成一个字符串,包含n个c字符
8) string s(str.begin(),str.end()) //以区间begin():end() (不包含end())内的字符作为字符串s的初值
#include <iostream> #include <string> using namespace std; int main () { //定义 string s0 ("abcdefghijklmn"); string s1; string s2 (s0); string s3(s0,3); string s4 (s0,3, 4); string s5 ("let us learn string"); string s6 ("let us learn string",6); string s7 (10, 'x'); string s8 (s0.begin(), s0.begin()+7); //输出 cout << "s1: " << s1 << "\ns2: " << s2 << "\ns3: " << s3; cout << "\ns4: " << s4 << "\ns5: " << s5 << "\ns6: " << s6; cout << "\ns7: " << s7 << "\ns8: " << s8 << '\n'; return 0; }
之后会对相关函数进行讲解,如果不想将下面操作函数全部看完,大伙可以找自己感兴趣的函数看。
1) =,assign() //赋以新值
2) swap() //交换两个字符串的内容
3)+=,append(),push_back() //在尾部添加字符
4) insert() //插入字符
5) erase() //删除字符
6) clear() //删除全部字符
7) replace() //替换字符
8) + //串联字符串
9)==,!=,<,<=,>,>=,compare() //比较字符串
10)size(),length() //返回字符数量
11) max_size() //返回字符的可能最大个数
12) empty() //判断字符串是否为空
13) capacity() //返回重新分配之前的字符容量
14) reserve() //保留一定量内存以容纳一定数量的字符
15) [ ], at() //存取单一字符
16)>>,getline() //从stream读取某值
17) << //将谋值写入stream
18) copy() //将某值赋值为一个C_string
19) c_str() //将内容以C_string返回
20) data() //将内容以字符数组形式返回
21) substr() //返回某个子字符串
22)查找函数
23)begin() end() //提供类似STL的迭代器支持
24) rbegin() rend() //逆向迭代器
25) get_allocator() //返回配置器
#include <string> #include <iostream> using namespace std; int main(void) { string s1; //尾部插入字符 s1.push_back('a'); s1.push_back('b'); s1.push_back('c'); cout << "打印s1: " << s1 << endl; char* cArray="efgh"; string s2(cArray); cout << "打印s2: " << s2 << endl; //字符串的"+"操作 cout << "打印s1+s2: " << s1 + s2 << endl; //字符串s1后添加字符串s2 cout << "append后,打印s1: " << s1.append(s2) << endl; //在s1的第个字符位置前插入字符'8' s1.insert(s1.begin()+1,'8'); cout << "insert后,打印s1: " << s1 << endl; //字符串的"+="操作 s1+=s2; cout << "s1+=s2后,打印s1: " << s1 << endl; return 0; }
#include <string> #include <iostream> using namespace std; int main(void) { char* cArray="hello, world!"; string s(cArray); //数组方式 for(unsigned int j=0; j< s.size(); j++) cout << "第" << j << "个字符: " << s[j] << endl; //迭代器方式 string::reverse_iterator ri; cout << "反向打印字符" << endl; for(ri=s.rbegin(); ri!=s.rend(); ri++) cout << *ri << ' ' ; cout << endl; return 0; }
1)iterator erase(iterator p);//删除字符串中p所指的字符
2)iterator erase(iterator first, iterator last);//删除字符串中迭代器
区间[first,last)上所有字符
3)string& erase(size_t pos = 0, size_t len = npos);//删除字符串中从索引
位置pos开始的len个字符
4)void clear();//删除字符串中所有字符
#include <string> #include <iostream> using namespace std; int main(void) { string s("12345678a"); s.erase(s.begin()); cout << s << endl; //打印出:a s.erase(s.begin()+3, s.end()-2); cout << s << endl; //打印出:a s.erase(0,2); cout << s << endl; //打印出:a s.clear(); return 0; }
1)string& replace(size_t pos, size_t n, const char *s);//将当前字符串
从pos索引开始的n个字符,替换成字符串s
2)string& replace(size_t pos, size_t n, size_t n1, char c); //将当前字符串
从pos索引开始的n个字符,替换成n1个字符c
3)string& replace(iterator i1, iterator i2, const char* s);//将当前字符串
[i1,i2)区间中的字符串替换为字符串s
#include <string> #include <iostream> using namespace std; int main(void) { string s("hello,boy!"); s.replace(6,3,"gril"); //boy替换为girl cout << s << endl; //打印hello gril! s.replace(10,1,1,'.'); //将"hello gril!"的'!'替换为'.' cout << s << endl; //打印hello gril. s.replace(s.begin(),s.begin()+5, "good morning"); cout << s << endl; //打印good morning girl. return 0; }
相关函数较多,下面列举几个常用的:
1)size_t find (constchar* s, size_t pos = 0) const;
//在当前字符串的pos索引位置开始,查找子串s,返回找到的位置索引,
-1表示查找不到子串
2)size_t find (charc, size_t pos = 0) const;
//在当前字符串的pos索引位置开始,查找字符c,返回找到的位置索引,
-1表示查找不到字符
3)size_t rfind (constchar* s, size_t pos = npos) const;
//在当前字符串的pos索引位置开始,反向查找子串s,返回找到的位置索引,
-1表示查找不到子串
4)size_t rfind (charc, size_t pos = npos) const;
//在当前字符串的pos索引位置开始,反向查找字符c,返回找到的位置索引,
-1表示查找不到字符
5)size_tfind_first_of (const char* s, size_t pos = 0) const;
//在当前字符串的pos索引位置开始,查找子串s的字符,返回找到的位置索引,
-1表示查找不到字符
6)size_tfind_first_not_of (const char* s, size_t pos = 0) const;
//在当前字符串的pos索引位置开始,查找第一个不位于子串s的字符,
返回找到的位置索引,-1表示查找不到字符
7)size_t find_last_of(const char* s, size_t pos = npos) const;
//在当前字符串的pos索引位置开始,查找最后一个位于子串s的字符,返回找到的位置索引,-1表示查找不到字符
8)size_tfind_last_not_of (const char* s, size_t pos = npos) const;
//在当前字符串的pos索引位置开始,查找最后一个不位于子串s的字符,返回找到的位置索引,-1表示查找不到子串
#include <string> #include <iostream> using namespace std; int main(void) { //0123456789012345678901234 string s("dog bird chicken bird cat"); //字符串查找 cout << s.find("bird") << endl; //打印 cout << (int)s.find("pig") << endl; //打印-1 //字符查找 cout << s.find('i',7) << endl; //打印 //从字符串的末尾开始查找字符串 cout << s.rfind("bird") << endl; //打印 //从字符串的末尾开始查找字符 cout << s.rfind('i') << endl; //打印 //查找第个属于某子串的字符 cout << s.find_first_of("13r98") << endl; //找到字符r,打印 //查找第个不属于某字符串的字符 cout << s.find_first_not_of("dog bird 2006") << endl; //找到字符c,打印 //查找最后一个属于某子串的字符 cout << s.find_last_of("13r98") << endl; //字符r,打印 //查找最后一个不属于某字符串的字符 cout << s.find_last_not_of("tea") << endl; //字符c,打印 return 0; }
1)int compare (conststring& str) const;//将当前字符串与字符串str比较,
相等返回0,大于str返回1,小于str返回-1
2)int compare (size_tpos, size_t len, const char* s) const; //将当前字符串从
Pos索引位置开始的len个字符构成的字符串与字符串s比较,
相等返回0,大于str返回1,小于str返回-1
3)int compare (constchar* s) const; //直接将当前字符串与字符串s比较,
相等返回0
#include <string> #include <iostream> using namespace std; int main(void) { string s1("abcdef"); string s2("abc"); cout << s1.compare("abcdef") << endl; //相等,打印 cout << s1.compare(s2) << endl; //s1 > s2,打印 cout << s1.compare("abyz") << endl; //s1 < "abyz",打印-1 cout << s1.compare(0,3,s2) << endl; //s1的前个字符==s2,打印 return 0; }
版权声明:本文为博主原创文章,未经博主允许不得转载。
原文地址:http://blog.csdn.net/lsh_2013/article/details/46728993