STL常用容器
string容器
string基本概念
- 本质: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 string& s );——使用字符串初始化 - string(const string& str);——使用一个string对象初始化另一个string对象;
- string(int n , char c );——使用n个字符c初始化
string s1; //空字符串
cout << "s1=" << s1 << endl;
const char* str = "Hello world";
string s2(str); //把c_string转换成了string
cout << "s2=" << s2 << endl;
string s3(s2);
cout << "s3=" << s3 << endl;
string s4(10, 'a');
总结:string的多种构造方式没有可比性,灵活使用即可
string的赋值操作:
- 给string字符串赋值:
string str1 = "hello world";
cout << "str1=" << str1 << endl;
string str2 = str1;
cout << "str2=" << str2 << endl;
string str3;
str3 = 'a';
cout << "str3=" << str3 << endl;
string str4;
str4.assign(str1); //str4.assign("hello c++");
cout << "str4=" << str4 << endl;
string str5;
str5.assign(str1, 5);
cout << "str5=" << str5 << endl;
string str6;
str6.assign(10, 'w');
cout << "str6=" << str6 << endl;
总结: string的赋值方式很多,operator= 这种方式是比较实用的
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个字符连接到字符串结尾
// 字符串拼接
void test01()
{
string str1 = "我";
str1 += "爱玩游戏";
cout << "str1 = " << str1 << endl;
str1 += ':';
cout << "str1 = " << str1 << endl;
string str2 = "LOL DNF";
str1 += str2;
cout << "str1 = " << str1 << endl;
string str3 = "I";
str3.append(" love ");
str3.append("game abcde", 4);
//str3.append(str2);
str3.append(str2, 4, 3); // 从下标4位置开始 ,截取3个字符,拼接到字符串末尾
cout << "str3 = " << str3 << endl;
}
int main() {
test01();
system("pause");
return 0;
}
总结:字符串拼接的重载版本很多,初学阶段记住几种即可
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; //查找字符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 test01()
{
//查找
string str1 = "abcdefgde";
int pos = str1.find("de");
if (pos == -1)
{
cout << "未找到" << endl;
}
else
{
cout << "pos = " << pos << endl;
}
pos = str1.rfind("de");
cout << "pos = " << pos << endl;
}
void test02()