C++从0到1 - 黑马程序员 课程学习笔记
课程链接:23 string容器-构造函数_哔哩哔哩_bilibili
1. String 容器
1.1 string基本概念
本质:
string是C++风格的字符串,而string本质上是一个类
string和char*的区别:
- char* 是一个指针
- string 是一个类,类内部封装了char*,管理这个字符串,是一个char*类型的容器
特点:
- string类内部封装了很多成员方法
- string管理char* 所分配的内存,不需要担心赋值越界和取值越界等,由类内部进行负责
1.2 string构造函数
构造函数原型:
string(); // 创建一个空的字符串,例如:string str
string(const char* s); // 使用字符串s初始化
string(const string& str); // 使用一个string对象初始化另一个string对象
string(int n,char c); // 使用n个字符c初始化
1.3 string赋值操作
函数原型:
string& operator=(const char* s); // char*类型字符串,赋值给当前的字符串
string& operator=(const string &s); // 把字符串s赋给当前的字符串
string& operator=(char c); // 字符赋值给当前的字符串
string& assign(const char *s); // 字符串s赋值给当前的字符串 string.assign()
string& assign(const char *s, int n); // 把字符串s的前n个字符赋值给当前字符串
string& assign(const string &s); // 把字符串s赋给当前字符串
string& assign(int n,char c); // 用n个字符c赋给当前字符串
1.4 string字符串拼接
功能描述:在字符串末尾拼接字符串
函数原型:
string& operator+=(const char* str) // 重载+=操作符
string& operator+=(const char c) // 重载+=操作符
string& operator+=(const string& str) // 重载+=操作符
string& append(const char *s); // 把字符串s连接到当前字符串结尾
string& append(const char *s, int n); // 把字符串s的前n个字符连接到当前字符串结尾
string& append(const string &s); // 同operator+=(const string& str)
string& append(const string &s,int pos,int n); // 字符串s中从pos开始的n个字符连接到字符串结尾
1.5 string查找和替换
功能描述:
- 查找:查找指定字符串是否存在
- 替换:在指定位置替换字符串
函数原型:
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; // 查找字符从最后一次出现位置
string& replace(int pos,int n,const string& str); // 替换从pos开始的n个字符为字符串str
string& replace(int pos,int n,const char* s); // 替换从pos开始的n个字符为字符串s
find和rfind的区别:find从左往右查找,rfind从右往左查找
1.6 string字符串比较
比较方式:
- 字符串比较是按字符的ASCII码进行对比
- = 返回 0
- > 返回 1
- < 返回 -1
函数原型:
int compare(const string &s) const;
int compare(const char *s) const;
1.7 string字符存取
char& operator[](int n); // 通过[]方式取字符
char& at(int n); // 通过at方法获取字符
1.8 string字符串插入和删除
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个字符
1.9 string子串获取
string substr(int pos=0,int n = npos) const; // 返回由pos开始的n个字符组成的字符串
举个
标签:const,string,STL,pos,C++,char,程序员,int,字符串
From: https://blog.csdn.net/rabbit_qi/article/details/137079356