✅作者简介:一名即将大三的计科专业学生,为C++,Java奋斗中
✨个人主页:叶落秋白的主页
🔥系列专栏:C++STL快速上手
📃推荐一款模拟面试、刷题神器👉注册免费刷题
🔥前言
书接上文,初始STL之后我们来学习最常见的一个引用类型——
string
容器,学习string容器的构造、以及C++API
中String类的常用方法,让我们一起来看看我们一直在用的字符串String的真面目吧!
✨string容器
string基本概念
本质:
- string是c++风格的字符串,不同于c语言的 char*,他本质是一个类
string 和 char*的区别:
- char*是一个
指针
- string是一个类,类内部封装了
char*
来管理字符串,是一个char&型的容器
特点:
strint类内部封装了很多成员方法
例如:查找find
,拷贝copy
,删除delete
,替换replace
,插入insert
string管理char*所分配的内存,不用考虑赋值越界和取值越界等问题,由类内部进行负责
string构造函数
四种函数原型
- string()创建一个空的字符串
- string(const char* s)使用字符串s初始化
- string(const string& str)使用一个string对象初始化另一个string对象
- string(int n,char c)使用n个字符c初始化
使用示例:
//string的构造函数
void test1()
{
string s1;//默认构造
const char* str = "叶落 秋白";
string s2(str);
cout << "s2:"<<s2 << endl;
string s3(s2);
cout << "s3" << s3 << endl;
string s4(6,'a');
}
上面就是四个构造方法对应的举例了,第一种方式是我们频繁使用的;第二种方式就是设置不可变字符数组传入构造来初始化;第三种方式理解为调用拷贝构造即可;第四种方式就比较有意思了,在上面代码里的意思就是用6个
'a'
来初始化字符串,输入s4结果为:aaaaaa。
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赋给当前字符串
使用示例:
void test2()
{
string str1;
str1 = "叶落秋白";
cout << "str1=" << str1 << endl;
string str2;
str2 = str1;
cout << "str2=" << str2 << endl;
string str3;
str3 = 'c';
cout << "str3=" << str3 << endl;
string str4;
str4.assign("hello c++");
cout << "str4=" << str4 << endl;
string str5;
str5.assign("hello c#",5);
cout << "str5=" << str5 << endl;
string str6;
str6.assign(str5);
cout << "str6=" << str6 << endl;
string str7;
str7.assign(6, 'w');
cout << "str7=" << str7 << endl;
}
tips:stirng赋值方法很多,但是重载的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 test3()
{
string str1 = "红豆";
str1 += "忆相思";
cout << "str1=" << str1<< endl;
str1 += '?';
cout << "str1=" << str1 << endl;
string str2 = "yyds";
str1 += str2;
cout << "str1=" << str1 << endl;
string str3 = "You";
str3.append("low");
cout << "str3=" << str3 << endl;
str3.append("wuwuwu qaq", 4);
cout << "str3=" << str3 << endl;
str3.append(str2);
cout << "str3=" << str3 << endl;
str3.append(str2, 0, 1);
cout << "str3=" << str3 << endl;
}
tips:初学者只需要稍微记几个拼接函数即可
string查找替换
- 指定位置查找字符串
- 指定位置删除字符串
函数原型:
- 查找s第一次出现位置,从pos开始查找
int find(const string& str, int pos = 0) const;
int find(const char* s , int pos ==0) const; - 从pos位置查找s的前n个字符第一次位置
int find( const char* s, int pos, int n) const; - 查找字符c第一次出现位置
int find(const char c, int pos = e) const; - 查找str最后一次位置,从pos开始查找
int rfind(const string& str, int pos = npos) const; - 查找str最后一次位置,从pos开始查找,计数永远是从前往后
int rfind(const char* s, int pos = npos) const; - 从pos查找s的前n个字符最后一次位置
int rfind(const char* s, int pos, int n) const; - 查找字符c最后一次出现位置
int rfind(const char c, int pos - e) const; - 替换从pos开始n个字符为字符串str
string& replace(int pos, int n, const string& str); - 替换从pos开始的n个字符为字符串s
string& replace(int pos, int n,const char* s );
使用示例:
//字符串的查找和替换
//查找
void test4()
{
string str1 = "abcdefgh";
//找到返回下标,找不到返回-1
int pos1 = str1.find("def");
cout << "pos1=" << pos1 << endl;
int pos2 = str1.find("s");
cout << "pos2=" << pos2<< endl;
pos1 = str1.rfind("ab");//从右往左找到第一个出现,从左往右计数
cout << "pos1=" << pos1 << endl;;
}
//替换
void test5()
{
string str2 = "abcdef";
str2.replace(1, 2, "1111");//从1号位置起,2个字符替换为1111
cout << "str2=" << str2 << endl;
}
tips:
find找到字符串后返回查找的第一个字符位置,找不到返回1
函数虽然很多,但几乎都是两个版本的,一个是c++风格一个c语言风格
string字符串比较
- 字符串比较是按字符的
ASCII码
进行对比
函数原型:
- int compare(const string &s) const;
- int compare(const char* s) const;
使用示例:
string str1 = “zello”;
string str2 = “hello”;
if (str1.compare(str2) == 0)
{
cout << “相等” << endl;
}
else if (str1.compare(str2) > 0)
{
cout << “str1大” << endl;
}
else
{
cout << “str2大” << endl;
}
tips:字符串对比的目的是比较两个字符串是否相等
,判断谁大谁小的意义并不是很大。
string字符读取
- 单个字符存取有两种方式:
函数原型:
- char& operator[] (int n); //通过[]获取字符
- char& at (int n); //通过at方法获取字符
使用示例:
string str1 = “hello”;
//通过[]访问单个字符
for (int i = 0; i < str1.size(); i++)
{
cout << str1[i] << " ";
}
cout << endl;
//通过at方式访问的单个字符
for (int i = 0; i < str1.size(); i++)
{
cout << str1.at(i) << " ";
}
cout << endl;
//修改单个字符
str1[0] = ‘z’;
cout << str1 << endl;
str1.at(0) = ‘x’;
cout << str1 << endl;
string插入和删除
函数原型:
- string& insert(int pos,const cahr* s);//在n位置插入字符串
- string& insert(int pos,const string& s);//在n位置插入字符串
- string& insert(int pos,int n,char c);//在指定位置插入n个字符c
- string& erase(int pos,int n = npos);//删除从pos位置开始的n个字符
使用示例:
string str = “hello”;
//插入
str.insert(1, “111”);
cout << "str = " << str << endl;
//删除
str.erase(1,3);
cout << "str = " << str << endl;
tips:插入和删除的起始下标都是从0
开始。
string求子串
- 从字符串中得到想要的子串
函数原型:
- string substr(int pos=0,int n=npos) const ;//返回由pos位置开始的由n个字符组成的字符串
//string求子串
void test01()
{
string str = "abcdef";
string subStr = str.substr(1, 3);
cout << "subStr=" << subStr << endl;
}
//使用操作
void test02()
{
string email = "ylqb@qq.com";
//从邮箱地址中获取用户名信息
int pos = email.find("@");
string usrName = email.substr(0, pos);
cout << usrName << endl;
}
tips:灵活的运用求子串功能,可以在实际开发中获取有效的信息,在上述代码中就可以有效获取到不同邮箱中的用户名。
📃结语
这是博主第一次自己理解着使用
markdown
编辑器创作博文,如果朋友们对于文章排版布局有好的建议一定要私信我哦,告诉我一些好用的快捷键。然后string容器的构造、初始化、常用方法就分享完了,知识点有点多,建议收藏起来,想不到方法的时候再看看,我们下一篇vector解析不见不散!
转载:https://blog.csdn.net/m0_58618795/article/details/125699203