string容器

string容器

​ 在c++中,字符串可以通过类来表示,也便是string容器,它本质上是通过一个类封装了char*指针,然后通过其内部的一些成员函数,能过对该字符串进行一些操作。

​ 它具有以下特性:

  1. string是一个类,它封装了一个char*指针,然后可以通过内部成员函数,操作该指针指向的字符串
  2. string管理char*所分配的内存,每一次string的赋值,都不用担心赋值越界和取值越界
  3. at()访问和[]不同,at越界能够抛出异常。
  4. s.at(i)和s[i]的区别在于s.at(i)若越界会抛出异常out_of_range

函数使用

赋值操作

  • string& assign(const char *s);//把字符串s赋给当前的字符串
  • string& assign(const char *s,int n);//把字符串s的前n个字符赋给当前的字符串
  • string& assign(const string &s);//把字符串s赋给当前字符串
  • string& assign(int n,char c);//用n个字符c赋给当前字符串

拼接操作

  • string& operator+=(const string& str);//重载+=操作符
  • string& operator+=(const char* str);//重载+=操作符
  • string& operator+=(const char c);//重载+=操作符
  • string& append(const char *s);//把字符串连接到当前字符串结尾
  • string& append(const char *s,int n);//把字符串的前n个字符连接到当前字符串结尾
  • string& append(const string &s);//同operator+=()
  • string& append(const string &s,int pos,int n);//把字符串s中从pos开始的n个字符连接到当前字符串结尾
  • string& append(int n,char c);//在当前字符串结尾添加n个字符c

查找和替换

  • int find(const string& str,int pos=0) const;//查找str第一次出现位置,从pos开始查找
  • int find(const char* s,int pos=0) const;//查找s第一次出现位置,从pos开始查找
  • int find(const char *s,int pos,int n) const;//从pos位置查找s的前n个字符第一次位置
  • int find(const char c,int pos=0) const;//查找字符c第一次出现的位置
  • int rfind(const string& str,int pos=npos) const;//查找str最后一次位置,从pos开始查找
  • int rfind(const char* s,int pos=npos) const;//查找s最后一次出现位置,从pos开始查找
  • int rfind(const char* s,int pos,int n) const;//从pos查找s的前n个字符最后一次位置
  • int rfind(const char c,int pos=0)const;//查找c的最后一次出现位置
  • string& replace(int pos,int n,const string& str);//替换从pos开始n个字符为字符串str
  • string& replace(int pos,int n,const char* s);//替换从pos开始的n个字符为字符串s

比较操作

compare函数在>0时返回1,<0时返回-1,==时返回0

比较区分大小写,参考字典顺序,排前面越小,大写比小写的要小

  • int compare(const string &s) const;//与字符串s比较
  • int compare(const char *s) const;//与字符串s比较

子串操作

  • string substr(int pos=0,int n=npos) const;//返回由pos开始的n个字符组成的字符串

插入/删除

  • string& insert(int pos,const char* s);//插入字符串
  • string& insert(int pos,const string& str);//插入字符串
  • string& insert(int pos,int n,char c);//在指定位置插入n个字符c
  • string& erase(int pos,int n=npos);//删除从pos开始的n个字符
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值