小言_互联网的博客

<C++>详解string容器,揭开string容器的神秘面纱

359人阅读  评论(0)

✅作者简介:一名即将大三的计科专业学生,为C++,Java奋斗中
✨个人主页:叶落秋白的主页
🔥系列专栏:C++STL快速上手
📃推荐一款模拟面试、刷题神器👉注册免费刷题

🔥前言

书接上文,初始STL之后我们来学习最常见的一个引用类型——string容器,学习string容器的构造、以及C++APIString类的常用方法,让我们一起来看看我们一直在用的字符串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
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场