一、string 容器
1、string 基本概念
本质:string 本质是一个类
string 和char *的区别 :
-
char* 是一个指针
-
string 是一个类,类内部封装了char * ,管理这个字符串,是一个char* 的容器
特点:
-
string类内部封装了很多成员方法,比如查找find,拷贝copy,删除delete,替换replace,插入insert
-
string管理 char* 所分配的内存,不用担心赋值越界和取值越界等,由类内部进行负责
2、string 构造函数
构造原型:
-
string() 创建一个空的字符串,例如string str
-
string(const char*s)使用字符串s初始化
-
string(const string &str) 使用一个string 对象初始化另一个 string 对象
-
string(int n, char c) 使用 n 个字符 c 初始化
/*
- string() 创建一个空的字符串,例如string str
- string(const char*s)使用字符串s初始化
- string(const string &str) 使用一个string 对象初始化另一个 string 对象
- string(int n, char c) 使用 n 个字符 c 初始化
*/
void test05(){
string s1;// 默认构造
const char * str = "hello word";
string s2(str);
cout << s2 << endl;
string s3(s2);
cout << s3 << endl;
string s4(10,'a');
cout << s4 << endl;
}
3、string 赋值操作
给 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 *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赋给当前字符串
*/
void test06(){
string str1 = "hahahhahnnnn";
string str2 = str1;
cout << str2 << endl;
string str3;
str3 = 'a';
cout << str3 << endl;
string str4;
str4.assign("hello");
cout << str4 << endl;
string str5;
str5.assign("hellosdfklsadkf",10);
cout << str5 << endl;
string str6;
str6.assign(str5);
cout << str6 << endl;
string str7;
str7.assign(10,'b');
cout << str7 << endl;
}
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(cosnt string & s) 同operator+=(const string & str)
-
string & append(const string & s, int pos,int n) 字符串s 中从pos 开始的n个字符连接到字符串结尾
/*
字符串拼接
- 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(cosnt string & s) 同operator+=(const string & str)
- string & append(const string & s, int pos,int n) 字符串s 中从pos 开始的n个字符连接到字符串结尾
*/
void test07(){
string str1 = "nnnnnnnnn";
str1 += "daihan";
cout << str1 << endl;
str1 +='a';
cout << str1 << endl;
string str2 = "XXXXX";
str1 += str2;
cout << str1 << endl;
str2.append("woc");
cout << str2 << endl;
str2.append("OOOOOOO",3);
cout << str2 << endl;
str2.append(str1);
cout << str2 << endl;
string str3 = "I123987654";
str2.append(str3,6,3);
cout << str2 << endl;
}
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 r,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
void test08(){
cout << "--------------" << endl;
string str1 = "ABCDEFGHI";
// 1、查找
cout << str1.find("CD") << endl; // 输出第一个的下标
cout << str1.find('H') << endl;
cout << str1.rfind("CD") << endl;
/*
rfind 和 find区别:
rfind 是从右往左查找
find 是从左往右查找
*/
// 2、替换
string str = "nnnnn";
str1.replace(1, 3, str);
cout << str1 << endl;
}
6、string 字符串比较
比较按照字符的ascll 码
=:0
: 1
<: -1
函数原型:
-
int compare(const string & s)const 与字符串s 比较
-
int compare(const char *s)const 与字符串s 比较
// 字符串比较
void test09(){
string s1 = "hhh";
string s2 = "xhh";
// 两个字符串相等就为 0
cout << s1.compare(s2) << endl;
}
7、string 字符存取
string 单个字符存取方式有两种:
char & operator [](int n) :通过【】方式取字符
char & at(int n):通过at方式存取
// string 字符存取
void te01(){
string str = "hashnn";
for (int i = 0; i < str.size(); i++) {
cout << str[i] << " ";
cout << str.at(i) << " ";
}
// 字符修改
cout << endl;
str[3] = 'q';
cout << endl;
cout << str << endl;
str.at(0) = 'p';
cout << str << endl;
}
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 & erass (int pos,int n = pos)删除从pos 开始 的n 个字符
void te02(){
string str = "hhhhhh";
str.insert(1, "aa"); // 在第一个位置插入两个aa
cout << str << endl;
str.erase(1,3);
cout << str << endl;
}
总结:插入和删除都是从 0 开始。
9、string 子串
从字符串中获取想要的子串
函数原型:
string substr(int pos = 0,int n = npos)const 放回由pos 开始的 n个字符组成的字符串
void te03(){
string str = "podfjgadkf";
cout << str.substr(1,4) << endl; // odfj
string st = "[email protected]";
int pos = st.find('@');
cout << st.substr(0,pos) << endl;
}