C++中的String的常用函数用法
一. string的构造函数的形式:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 |
|
二. string的大小和容量::
1 2 3 4 5 |
|
1 2 3 4 5 6 7 8 9 |
|
三. string的字符串比较:
1. C ++字符串支持常见的比较操作符(>,>=,<,<=,==,!=),甚至支持string与C-string的比较(如 str<”hello”)。 在使用>,>=,<,<=这些操作符的时候是根据“当前字符特性”将字符按字典顺序进行逐一得 比较。字典排序靠前的字符小, 比较的顺序是从前向后比较,遇到不相等的字符就按这个位置上的两个字符的比较结果确定两个字符串的大小(前面减后面) 同时,string (“aaaa”) <string(aaaaa)。 2. 另一个功能强大的比较函数是成员函数compare()。他支持多参数处理,支持用索引值和长度定位子串来进行比较。 他返回一个整数来表示比较结果,返回值意义如下:0:相等 1:大于 -1:小于 (A的ASCII码是65,a的ASCII码是97)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 |
|
四. string的插入:push_back() 和 insert()
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
|
五、string拼接字符串:append() & + 操作符
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
|
六、 string的遍历:借助迭代器 或者 下标法
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 |
|
七、 string的删除:erase()
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();//删除字符串中所有字符
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
|
八、 string的字符替换:
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
1 2 3 4 5 6 7 8 9 10 11 12 13 |
|
九、 string的大小写转换:tolower()和toupper()函数 或者 STL中的transform算法
方法一:使用C语言之前的方法,使用函数,进行转换
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
|
方法二:通过STL的transform算法配合的toupper和tolower来实现该功能
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
|
十、 string的查找:find
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表示查找不到子串
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 |
|
十一、 string的排序:sort(s.begin(),s.end())
1 2 3 4 5 6 7 8 9 10 11 |
|
十二、 string的分割/截取字符串:strtok() & substr()
strtok():分割字符串
1 2 3 4 5 6 7 8 9 10 11 12 |
|
1 2 3 4 5 6 |
|
到此这篇关于C++中的String的常用函数用法的文章就介绍到这了