C++ 顺序容器-string容器的基本操作

本文详细介绍了C++ STL中的string容器,包括其概念、构造函数、存取操作、转换为const char*、拷贝到char*空间、长度获取、赋值、字符串连接、比较、子串操作、查找与替换以及区间删除和插入等基本操作。

1. string的概念

  • string 是 STL 的字符串类型,通常用来表示字符串
  • string是一个类,而char*是一个指向字符的指针
  • string封装了char*,是一个char*型的容器
  • 使用string不用考虑内存的释放问题,由string本身负责维护
  • 引入头文件:#include

2. string的构造函数

// 默认构造函数
string();   // 生成一个空串

// 拷贝构造函数
string(const string &str);  

// 带参数的构造函数
string(const char *s);   // 用字符数组s初始化
string(int n, char c);    // 用n个字符c初始化

3. string的存取操作

  • 主要是[]操作符和at方法
  • 两者区别:
    • at()方法在越界时会抛出异常
    • 而[]操作符在刚好越界时返回(char)0,再继续越界时,直接报错
// []操作符存取某个位置n上的数据
const char &operator[] (int n) const;
char &operator[] (int n);

// at方法存取某个位置n上的字符
const char &at(int n) const;
char &at(int n);
// 示例
string s = "sfjei";
s.at(1);   // 返回字符f
s[1];  // 返回字符f

4. string对象转成const char*操作

const char *c_str() const;  //返回一个以'\0'结尾的字符串的首地址

5. 把string对象拷贝到char *指向的内存空间

  • 保证char *所指向的内存空间足够大以容纳当前拷贝的字符串
// 将当前串中以 pos 开始的 n 个字符拷贝到以 s 为起始位置的字符数组中
// 返回值:实际拷贝的数目
int copy(char *s, int n, int pos=0) const;
// 示例
string s1 = "abcde";
char c_s[10];
int k = s1.copy(c_s, 3, 1);

6. string的长度

int length() const; //返回当前字符串的长度。长度不包括字符串结尾的'\0'。
bool empty() const; //当前字符串是否为空

7. string 的赋值

// =操作符赋值
string &operator=(const string &s);//把字符串 s 赋给当前的字符串

// assign方法赋值
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 &assign(const string &s,int start, int n); //把字符串 s 中从 start 开始的 n 个字符赋给当前字符串

8. string 字符串连接

// +=连接操作符,返回当前字符串的引用
string &operator+=(const string &s); //把字符串 s 连接到当前字符串结尾
string &operator+=(const char *s);//把字符串 s 连接到当前字符串结尾

// append方法连接字符,将char*所指向的字符串连接到当前串
// 返回当前串的引用
string &append(const char *s); //把字符串 s 连接到当前字符串结尾
string &append(const char *s,int n); //把字符串 s 的前 n 个字符连接到当前字符串结尾

// append方法连接字符,将string字符串连接到当前串
// 返回当前串的引用
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

9. string 的比较

  • compare函数在 > 时返回1,< 时返回-1,== 时返回0
  • 区分大小写
int compare(const string &s) const; //与字符串 s 比较

int compare(const char *s) const; //与char*所指向的字符串比较

10 string 的子串

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

11 string 的查找 和 替换

查找

// 正向查找,如果查找不到,就返回-1
int find(char c,int pos=0) const; //从 pos 开始查找字符 c 在当前字符串的位置
int find(const char *s, int pos=0) const; //从 pos 开始查找字符串 s 在当前字符串的位置
int find(const string &s, int pos=0) const; //从 pos 开始查找字符串 s 在当前字符串中的位置

// 反向查找,如果查找不到, 返回-1
int rfind(char c, int pos=npos) const; //从 pos 开始从后向前查找字符 c 在当前字符串中的位int rfind(const char *s, int pos=npos) const;
int rfind(const string &s, int pos=npos) const;

替换

string &replace(int pos, int n, const char *s);//删除从 pos 开始的 n 个字符,然后在 pos 处插入串 s
string &replace(int pos, int n, const string &s); //删除从 pos 开始的 n 个字符,然后在 pos 处插入串 s
void swap(string &s2); //交换当前字符串与 s2 的值

12 String 的区间删除和插入

// 在 pos 位置插入字符串 s
string &insert(int pos, const char *s);
string &insert(int pos, const string &s);

//在 pos 位置插入字符n个字符c
string &insert(int pos, int n, char c); //在 pos 位置 插入 n 个字符 c

// 删除
string &erase(int pos=0, int n=npos); //删除 pos 开始的 n 个字符,返回修改后的字符串
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值