c++ string功能函数

一. string的构造函数的形式

string str:生成空字符串
string s(str):生成字符串为str的复制品
string s(str, str_begin, str_len):将字符串str中从下标strbegin开始、长度为strlen的部分作为字符串初值
string s(cstr, char_len):以C_string类型cstr的前char_len个字符串作为字符串s的初值
string s(num, char):生成num个c字符的字符串
string s(str, str_index):将字符串str中从下标str_index开始到字符串结束的位置作为字符串初值
string str1; //生成空字符串
string str2(“123456789”); //生成"1234456789"的复制品
string str3(“12345”, 0, 3); //结果为"123"
string str4(“012345”, 5); //结果为"01234"
string str5(5, ‘1’); //结果为"11111"
string str6(str2, 2); //结果为"3456789"

二. string的大小和容量

size()和length():返回string对象的字符个数,他们执行效果相同。
max_size():返回string对象最多包含的字符数,超出会抛出length_error异常
capacity():重新分配内存之前,string对象能包含的最大字符数
string str(“1234567”);
cout << “size=” << s.size() << endl; // size=7
cout << “length=” << s.length() << endl; // length=7
cout << “max_size=” << s.max_size() << endl; // max_size=4294967294
cout << “capacity=” << s.capacity() << endl; // capacity=15

三. string的字符串比较

比较操作符: >, >=, <, <=, ==, !=
这些操作符根据“当前字符特性”将字符按字典顺序进行逐一比较,字典排序靠前的字符小,比较的顺序是从前向后比较,遇到不相等的字符就按这个位置上的两个字符的比较结果确定两个字符串的大小(前面减后面)
成员函数compare()
支持多参数处理,支持用索引值和长度定位子串进行比较,前面减去后面的ASCII码,>0返回1,<0返回-1,相同返回0
str1.compare(str2):compare str1[0, _Mysize) with _Right
str1.compare(_Off, _N0, str2):compare str1[_Off, _Off + _N0) with str2
str1.compare(_Off, _N0, str2, _Roff, _Count):compare str1[_Off, _Off + _N0) with str2[_Roff, _Roff + _Count)
str1.compare(*_Ptr):compare str1[0, _Mysize) with [_Ptr, )
str1.compare(_Off, _N0, *_Ptr, _Count):compare str1[_Off, _Off + _N0) with [_Ptr, _Ptr + _Count)
string A(“aBcdf”);
string B(“AbcdF”);
string C(“123456”);
string D(“123dfg”);

cout << “A.compare(B):” << A.compare(B) << endl; //"aBcdf"和"AbcdF"比较,a>A,返回1
cout << “A.compare(2, 2, B):” << A.compare(2, 2, B)<< endl; //"cd"和“AbcdF"比较,c>A,返回1
cout << “A.compare(2, 2, B, 2, 2):” << A.compare(2, 2, B, 2, 2) << endl; //"cd"和“cd"比较,返回0
cout << “C.compare(0, 4, D, 0, 4):” << C.compare(0, 4, D, 0, 4)<< endl; //"1234"和"123d"比较,返回-1

四. string的插入:push_back() 和 insert()

// 尾插一个字符
s1.push_back('a');
s1.push_back('b');
s1.push_back('c');
cout<<"s1:"<<s1<<endl; // s1:abc

// insert(pos,char):在制定的位置pos前插入字符char
s1.insert(s1.begin(),'1');
cout<<"s1:"<<s1<<endl; // s1:1abc

五、string拼接字符串:append() 、 +

//方法一:append()
string s1(“abc”);
s1.append(“def”);
cout<<“s1:”<<s1<<endl; // s1:abcdef

// 方法二:+ 操作符
string s2 = “abc”;
/s2 += “def”;/
string s3 = “def”;
s2 += s3.c_str();
cout<<“s2:”<<s2<<endl; // s2:abcdef

六、 string的遍历:借助迭代器 或者 下标法

正向迭代器 str.begin()、str.end()
反向迭代器 str.rbegin()、str.rend()
string s1(“abcdef”);

// 正向迭代器
string::iterator iter = s1.begin();
for( ; iter < s1.end() ; iter++)
{
cout<<*iter;
}
cout<<endl; //abcdef

// 反向迭代器
string::reverse_iterator riter = s1.rbegin();
for( ; riter < s1.rend() ; riter++)
{
cout<<*riter;
}
cout<<endl; //fedcba

七、 string的删除:erase()

iterator erase(iterator p):删除字符串中p所指的字符
iterator erase(iterator first, iterator last):删除字符串中迭代器区间 [first, last) 上所有字符
string& erase(size_t pos, size_t len):删除字符串中从索引位置 pos 开始的 len 个字符
void clear():删除字符串中所有字符
string s1 = “123456789”;

s1.erase(s1.begin() + 1); // 结果:13456789
s1.erase(s1.begin() + 1, s1.end() - 2); // 结果:189
s1.erase(1,6); // 结果:189

八、 string的字符替换

string& replace(size_t pos, size_t n, const char s):将当前字符串从pos索引开始的n个字符,替换成字符串s
string& replace(size_t pos, size_t n, size_t n1, char c):将当前字符串从pos索引开始的n个字符,替换成n1个字符c
string& replace(iterator i1, iterator i2, const char
s):将当前字符串[i1,i2)区间中的字符串替换为字符串s
string s1(“hello,world!”);

s1.replace(6, 5, “girl”); // 结果:hello,girl.
s1.replace(s1.size() - 1, 1, 1, ‘.’); // 结果:hello,world.
s1.replace(s1.begin(), s1.begin() + 5, “boy”); // 结果:boy,girl.

九、string大小写转换:tolower() 和 toupper() 或者 STL中的 transform 算法

tolower(char) 和 toupper(char) :将字符进行大小写转换
transform(_InIt _First, _InIt _Last, _OutIt _Dest, _Fn1 _Func):transform [_First, _Last) with _Func
string s = “ABCDEFG”;

for( int i = 0; i < s.size(); i++ )
{
s[i] = tolower(s[i]);
}
cout << s << endl; //abcdefg

transform(s.begin(), s.end(), s.begin(), ::toupper);
cout << s << endl; //“ABCDEFG”

十、 string的查找:find

find (const char* s, size_t pos):在当前字符串的pos索引位置开始,查找子串s,返回找到的位置索引
find (char c, size_t pos):在当前字符串的pos索引位置开始,查找字符c,返回找到的位置索引
rfind (const char* s, size_t pos):在当前字符串的pos索引位置开始,反向查找子串s,返回找到的位置索引
rfind (char c, size_t pos):在当前字符串的pos索引位置开始,反向查找字符c,返回找到的位置索引
find_first_of (const char* s, size_t pos):在当前字符串的pos索引位置开始,查找子串s的字符,返回找到的位置索引
find_first_not_of (const char* s, size_t pos):在当前字符串的pos索引位置开始,查找第一个不位于子串s的字符,返回找到的位置索引
find_last_of(const char* s, size_t pos):在当前字符串的pos索引位置开始,向前查找第一个位于子串s的字符,返回找到的位置索引
find_last_not_of (const char* s, size_t pos):在当前字符串的pos索引位置开始,向前查找第一个不位于子串s的字符,返回找到的位置索引
string s(“dog bird chicken bird cat”);

//字符串查找-----找到后返回首字母在字符串中的下标
// 1. 查找一个字符串
cout << s.find(“chicken”) << endl; // 结果是:9

// 2. 从下标为6开始找字符’i’,返回找到的第一个i的下标
cout << s.find(‘i’, 6) << endl; // 结果是:11

// 3. 从字符串的末尾开始查找字符串,返回的还是首字母在字符串中的下标
cout << s.rfind(“chicken”) << endl; // 结果是:9

// 4. 从字符串的末尾开始查找字符
cout << s.rfind(‘i’) << endl; // 结果是:18

// 5. 在该字符串中查找第一个属于字符串s的字符
cout << s.find_first_of(“13br98”) << endl; // 结果是:4(“b”)

// 6. 在该字符串中查找第一个不属于字符串s的字符,先匹配dog,然后bird匹配不到,所以打印4
cout << s.find_first_not_of(“hello dog 2006”) << endl; // 结果是:4

// 7. 在该字符串从后往前查找第一个属于字符串s的字符
cout << s.find_last_of(“13r98”) << endl; // 结果是:19

// 8. 在该字符串从后往前查找第一个不属于字符串s的字符,先匹配tac,然后空格匹配不到,所以打印21
cout << s.find_last_not_of(“teac”) << endl; // 结果是:21

十一、 string的排序

sort(iterator iter1, iterator iter2):对[iter1, iter2)进行排序

string s = “cdbaef”;
sort(s.begin(), s.begin() + 3);
cout << “s:” << s << endl; //s:bcdaef

十二、 string的分割/截取字符串:substr()

string s1(“0123456789”);
string s2 = s1.substr(2, 5);
cout << s2 << endl; // 结果:23456,参数5表示截取的字符串的长度

string str(“I,am,a,student; hello world!”);
string split(",; !");

int iCurrentIndex = 0;
int iSplitIndex;
while (iCurrentIndex < str.size()) {
iSplitIndex = str.find_first_of(split, iCurrentIndex);
if (iSplitIndex == -1)
iSplitIndex = str.size();

if (iSplitIndex != iCurrentIndex)
    cout << str.substr(iCurrentIndex, iSplitIndex - iCurrentIndex) << endl;
    
 iCurrentIndex = iSplitIndex + 1;

}
/**********************************
结果:
I
am
a
student
hello
world
*/

作者:第八天的蝉啊
链接:https://www.jianshu.com/p/c86d38db63ce
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值