一.概念/本质:
*string是C++风格的字符串,而string本质上是一个类
string和char*区别:
1..char*是一个指针
2.string是一个类,类内部封装了char*,管理这个字符串,是一个char*型的容器。
特点:
string 类内部封装了很多成员方法
例如: 查找find,拷贝copy,删除delete 替换replace,插入insert
string管理char*所分配的内存,不用担心复制越界和取值越界等,由类内部进行负责
二.string构造函数
构造函数原型:
*string(); //创建一个空的字符串 例: string str;
string(const char* s); //使用字符串s初始化
*string(const string& str);//使用一个string对象初始化另一个string对象
*string(int n, char c); //使用n个字符C初始化
例子:
string s1;//默认构造
const char* str = "hell0 world";
string s2(str);//使用字符串s初始化
cout << "s2=" << s2 << endl;
string s3(s2);//使用一个string对象初始化另一个string对象
cout << "s3=" << s3 << endl;
string s4(10, 'a'); //使用n个字符C初始化
cout << "s4=" << s4 << endl;
三.sttring赋值操作
功能描述:给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(const char *s, int n); //把字符串s的前n个字符赋给当前的字符串
*string& assign(const string &s); //把字符串s赋给当前字符串
*string& assign(int n, char c); //用n个字符c赋给当前字符串
四.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(gonst string &s); //同operator+=(const string& str)
*string& append(const string &sint pos,int n); //字符s中从pos开始的n个字符连接到字符串结尾
例子:
string str1 = "我";
cout << "str1=" << str1 << endl;
str1 += ';';//重载+=操作符
cout << "str1=" << str1 << endl;
string str2 = "LOL DNF";
string str3 = "I";
str3.append("love "); //把字符串s连接到当前字符串结尾
cout << "str3 = "<< str3 << endl;
str3.append("game abcde",4);//把字符串s的前n个字符连接到当前字符串结尾
// 上面代码打印:I love game
cout << "str3 = "<<str3 << endl;
str3. append(str2);
str3.append(str2,0,3); //只截取到LOL//字符s中从pos开始的n个字符连接到字符串结尾
//从第0个字符开始,截取3个字符
五.string查找和替换
功能描述:
1.查找:查找指定字符串是否存在.
2.替换:在指定的位置替换字符串
函数原型:
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
例子:
//1.查找
void test01()
{
string str1 = "abcdefg";
int pos = str1.find("de");//如果写df,那么索引不到会返回-1
//那么就可以利用这一点实现判断语句,判断pos是否==-1
cout << "pos=" << pos << endl;
//rfind
//rfind和find的区别: rfind从右到左查找 find从左到右查找
pos = str1.rfind("de");
}
//2.替换
void test02()
{
string str1 = "abcdefg";
//从1号位置起3个字符 替换成"1111"
str1.replace(1, 3, "1111");
cout << "str1=" << str1 << endl;
}
string查找和替换 总结:
1.find查找是从左往后,rfind从右往左
2.find找到字符串后返回查找的第一个字符位置,找不到返回-1
3.replace在替换时,要指定从哪个位置起,多少个字符,替换成什么样的字符串
仅个人看视频笔记与理解,如有误可指出谢谢