c++中string的函数 用法总结 !!!

一.string的构造函数的形式

参见cplusplus官网的声明

//default (1)           //string();	生成空字符串
//copy(2)               //string(const string& str);//拷贝一份字符串str
//substring(3)          //string(const string& str, size_t pos, size_t len = npos);//从制定str的pos位置开始拷贝npos个字符
//from c - string(4)    //string(const char* s);//生成一个由c_str构造的字符串
//from sequence(5)     //string(const char* s, size_t n);//从c_str中拷贝n个字符
//fill(6)              //string(size_t n, char c);//生成n个c字符的字符串
//range(7)             //template <class InputIterator>//迭代器
//string(InputIterator first, InputIterator last);

int main()
{
	string s1;
	string s2("123456789");
	string s3("12345", 0, 3);
	string s4("123455", 5);
	string s5(5, '1');
	string s6(s2, 2);
	string s7(s6.begin(), s6.end());

	return 0;
}

二、string的大小和容量

1.size()和length();返回string对象的字符个数

2.max_size() 返回string对象 包含的最大字符数量 ,超出容量会抛出异常

3.capacity() 返回此时string对象的容量。

三、string字符串的比较

1、c++标准中支持(>,>=,<,<=,++,!=), 在进行怕排序的时候从第一个字符开始按照字典序进行逐一比较,遇到不相等字符的时候通过比较的结果确定两个字符串的大小。

例:string("abdc")>string("abcdefg");

2、compare比较函数,支持多参处理,支持索引值和长度定位子串来进行比较,返回一个整数值来表示比较结果 吗,0:相等,1:大于,-1:小于。

4、string的插入:push_back()和insert()

insert:在制定的pos位置插入字符;

push_ back:在字符串的最后一个位置插入字符; 

5.string拼接字符串:append()&+操作符

6.string的遍历:借助迭代器或者范围for,下标

    string s1("abcdefg");
    //下标法
    for (int i = 0; i < s1.size(); i++)
    {
        cout << s1[i] << " ";
    }
    cout << endl;
    //迭代器
    string::iterator it1 = s1.begin();
    while (it1 != s1.end())
    {
        cout << *it1 << " ";
        it1++;
    }
    cout << endl;
    //范围for
    for (auto e : s1)
    {
        cout << e << " ";
    }

 

7.string的删除:erase()

 

sequence (1)
 string& erase (size_t pos = 0, size_t len = npos);//从pos位置开始删除len个字符
character (2)
iterator erase (iterator p);删除迭代器所指位置的字符
range (3)
     iterator erase (iterator first, iterator last);//删除迭代器区间的所有字符

     string s1("abcdefgh");
    s1.erase(3, 2);//从d开始删两个字符'd'和'e',"abcdefgh"->"abcefgh"
    cout << s1 << endl;
    s1.erase(s1.begin() + 2);// 删除‘c’,"abcefgh"->"abefgh"
    cout << s1 << endl;
    s1.erase(s1.begin(), s1.begin() + 2);//从开始到开头位置+2,“abefgh”->" fgh";
    cout << s1 << endl;

 8.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个字符替换成字符c

3.string &replace(itearator it1,itearator it2,const char*s)//将当前字符串【it1,it2)区间的字符替换成字符串s

     string s1("abcdefgh");
    s1.replace(2, 3, "kkk");
    cout << s1 << endl;
    s1.replace(2, 4,3, 'k');
    cout << s1 << endl;
    s1.replace(s1.begin(), s1.begin() + 4,"jjjjj");
    cout << s1 << endl;

9.string 的查找:find()

string (1)
size_t find (const string& str, size_t pos = 0) const;//从字符串的pos索引位置开始查找子串str,如果找到返回位置索引,找不到返回-1;
c-string (2)
size_t find (const char* s, size_t pos = 0) const;从字符串的pos索引位置开始查找子串str,如果找到返回位置索引,找不到返回-1;
buffer (3)
size_t find (const char* s, size_t pos, size_t n) const;
character (4)
size_t find (char c, size_t pos = 0) const;//从索引pos位置开始查找字符c,找到返回位置索引

     string s1("abcdfgh");
    size_t n=s1.find("bcd");
    cout << n << endl;
    size_t n1 = s1.find("bdc", 2);//找不到返回随机值
    cout << n1 << endl;
    size_t n2 = s1.find('c');
    cout << n2 << endl;

 10.string的排序:sort(s.begin(),s.end())(引用算法头文件:algorithm)

#include<iostream>
#include<algorithm>

#include<string>

using namespace std;

int main()

{

string s1("asdfasfgf");

sort(s1.begin(),s1.end());

cout<<s1<<endl;

return 0;

}

11.分割字符串/截取字符串:strtok()或者substr()

 

 char s1[] = "abcc,def.gh/";
const char *s2=",./";
const char* p2 = strtok(s1,s2);
while (p2!=NULL)
{

    cout <<  p2 << endl;
    p2 = strtok(NULL, s2);
}

 

string s1("abcdefg");

string s2=substr(str,2,3);

cout<<s2<<endl;

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值