【C++】:string类的基本使用

devtools/2024/10/18 14:25:53/

目录

  • 引言
  • 一,string类对象的常见构造
  • 二,string类对象的容量操作
  • 三,string类对象的访问及遍历操作
  • 四,string类对象的修改操作
  • 五,string类非成员函数
  • 六,整形与字符串的转换

引言

string 就是我们常说的"串",它是一种字符数组,只不过这个数组具备扩容,增删查改等功能。string类在我们日常生活中是十分常用的,并且在笔试,面试中也经常出现,它是学习C++的不可缺少的一部分。

string类大概有120个函数接口,注意下面只讲解最常用的接口,想要了解更多,前往https://legacy.cplusplus.com/reference/string/string/网站里浏览。

一,string类对象的常见构造

在这里插入图片描述

代码演示:

void test_string1()
{string s1;//无参默认构造string s2("hello world");//用字符串构造//从str中的pos下标位置,拷贝len个字符string s4(s2, 3, 5);//不传第三个参数,默认拷贝到结尾,缺省参数npos是整型最大值string s5(s2, 3);string s3(s2);//拷贝构造
}

二,string类对象的容量操作

在这里插入图片描述

代码演示1:

// size/clear/resize
void Test_string2()
{// 注意:string类对象支持直接用cin和cout进行输入和输出string s("hello, world!!!");cout << s.size() << endl;//计算字符个数,不算\0cout << s.length() << endl;cout << s.capacity() << endl;cout << s << endl;// 将s中的字符串清空,注意清空时只是将size清0,不改变底层空间的大小s.clear();cout << s.size() << endl;cout << s.capacity() << endl;// 将s中有效字符个数增加到10个,多出位置用'a'进行填充//当传的值大于size时,此时会影响capacity+size,两个都会增加// “aaaaaaaaaa”s.resize(10, 'a');cout << s.size() << endl;cout << s.capacity() << endl;// 将s中有效字符个数增加到15个,多出位置用缺省值'\0'进行填充// "aaaaaaaaaa\0\0\0\0\0"// 注意此时s中有效字符个数已经增加到15个s.resize(15);cout << s.size() << endl;cout << s.capacity() << endl;cout << s << endl;// 将s中有效字符个数缩小到5个s.resize(5);cout << s.size() << endl;cout << s.capacity() << endl;cout << s << endl;
}

代码演示1:

//测试reserve
void test_string3()
{string s;//一般用在知道需要多少空间,提前开好s.reserve(100);string s1("111111111");cout << s1.capacity() << endl;//15//扩容//reserve只影响capacity,不影响size,即不改变里面的数据s1.reserve(100);cout << s1.capacity() << endl;//111//缩容//传的值比当前的capacity小时,// vs一般不缩容,g++会缩s1.reserve(10);cout << s1.capacity() << endl;//15
}

注意:

  1. size()与length()方法底层实现原理完全相同,引入size()的原因是为了与其他容器的接口保持一致,一般情况下基本都是用size()。
  2. clear()只是将string中有效字符清空,使size = 0,不改变底层空间大小。
  3. resize(size_t n) 与 resize(size_t n, char c)都是将字符串中有效字符个数改变到n个,不同的是当字符个数增多时:resize(size_t n)用0来填充多出的元素空间,resize(size_t n, char c)用字符c来填充多出的元素空间。注意:resize在改变元素个数时,如果是将元素个数增多,可能会改变底层容量的大小,如果是将元素个数减少,底层空间总大小不变。
  4. reserve(size_t res_arg=0):为string预留空间,不改变有效元素个数,当reserve的参数小于string的底层空间总大小时,reserver不会改变容量大小。

三,string类对象的访问及遍历操作

string类对象的访问及遍历有三种方式:
1. 迭代器:begin()+end()
2. for+[]
3. 范围for

注意:string遍历时使用最多的还是for+下标 或者 范围for(C++11后才支持)

begin()+end()大多数使用在需要使用STL提供的算法操作string时,比如:采用reverse逆置string,使用sort按字典序排序(按ASCII码值排序)。

代码演示:

void Teststring4()
{string s("hello Bit");// 3种遍历方式:// 需要注意的以下三种方式除了遍历string对象,还可以遍历是修改string中的字符,// 另外以下三种方式对于string而言,第一种使用最多// 1. for+operator[]for (size_t i = 0; i < s.size(); ++i)cout << s[i] << endl;// 2.迭代器string::iterator it = s.begin();while (it != s.end()){cout << *it << endl;++it;}// string::reverse_iterator rit = s.rbegin();// C++11之后,直接使用auto定义迭代器,让编译器推到迭代器的类型auto rit = s.rbegin();while (rit != s.rend()){cout << *rit << endl;}// 3.范围for//自动取出s中的数据赋给ch,自动判断结束,自动++。//其实底层就是迭代器。for (auto ch : s){cout << ch << endl;}
}

使用sort按字典序排序(按ASCII码值排序):

void test_string5()
{string s1("hello world");cout << s1 << endl;//按字典序排序(按ASCII码值排序)//用排序函数sort [first last)左闭右开,last传的不是有效数据//sort(s1.begin(), s1.end());//第一个和最后一个不参与排序//sort(++s1.begin(), --s1.end());//前5个排序  [0,5)sort(s1.begin(), s1.begin() + 5);cout << s1 << endl;
}

四,string类对象的修改操作

在这里插入图片描述

  1. 插入(拼接)方式:push_back append operator+=
  2. 正向和反向查找:find() + rfind()
  3. 截取子串:substr()
  4. 删除:erase

代码演示1:

void test_string6()
{string s1("hello world");cout << s1 << endl;s1.push_back('x');//一个字符一个字符尾插cout << s1 << endl;s1.append(" yyyyyyy!!");//尾插一个字符串cout << s1 << endl;string s2("22222");//直接尾插s1 += 'aaa';s1 += 'd';s1 += s2;cout << s1 << endl;
}

代码演示2:

void test_string7()
{// 获取file的后缀string file("string.cpp");//从后往前找'.'size_t pos = file.rfind('.');string suffix(file.substr(pos, file.size() - pos));cout << suffix << endl;// npos是string里面的一个静态成员变量// static const size_t npos = -1;// 取出url中的域名string url("http://www.cplusplus.com/reference/string/string/find/");cout << url << endl;size_t start = url.find("://");if (start == string::npos){cout << "invalid url" << endl;return;}start += 3;size_t finish = url.find('/', start);string address = url.substr(start, finish - start);cout << address << endl;// 删除url的协议前缀pos = url.find("://");url.erase(0, pos + 3);cout << url << endl;
}

注意:

  1. 在string尾部追加字符时,s.push_back( c ) / s.append(1, c) / s += 'c’三种的实现方式差不多,一般情况下string类的+=操作用的比较多,+=操作不仅可以连接单个字符,还可以连接字符串。
  2. 对string操作时,如果能够大概预估到放多少字符,可以先通过reserve把空间预留好。

五,string类非成员函数

![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/0d01f1518e0e4654a84bd21e221afb38.png

代码演示1:

void test_string8()
{string s1 = "hello";string s2 = "world";string ret1 = s1 + s2;cout << ret1 << endl;string ret2 = s1 + "xxxxx";cout << ret2 << endl;string ret3 = "xxxxx" + s1;cout << ret3 << endl;//按字典序比较cout << (s1 < s2) << endl;
}

代码演示2:

int main()
{string str;string str2;//如何停止输入?//ctrl+c//ctrl+z+空格//	while (cin >> str2)//	{//		cout << str2 << endl;//	}//cin 遇到空格或者换行会停止提取//cin >> str;//获取一行包含空格的字符串getline(cin, str);int pos = str.rfind(' ');cout << str.size() - (pos + 1) << endl;return 0;
}

六,整形与字符串的转换

int main()
{int x = 0, y = 0;cin >> x >> y;//to_string:整形转字符串string str = to_string(x + y);cout << str << endl;//stoi:字符串转整形int aa = stoi(str);cout << aa << endl;return 0;
}

http://www.ppmy.cn/devtools/42017.html

相关文章

关于提高 PHP 性能

解锁 PHP 性能&#xff1a;优化你的 Web 应用 在当今数字化世界中&#xff0c;Web 应用的性能对用户体验至关重要。作为最流行的服务器端脚本语言之一&#xff0c;PHP 在构建 Web 应用方面拥有广泛的应用。然而&#xff0c;PHP 应用的性能优化仍然是许多开发者关注的焦点之一。…

PDK安装及简介

目录 PDK简介 pdk安装 Standard Cell Library简介 IO Library简介 PDK简介 PDK&#xff1a;全称Process Design Kit&#xff0c;是工艺设计工具包的缩写&#xff0c;是制造和设计之间的沟通桥梁&#xff0c;是模拟电路设计的起始点。 具体来说&#xff0c;PDK是代工厂(FAB…

Linux 权限

个人主页&#xff1a;仍有未知等待探索-CSDN博客 专题分栏&#xff1a;Linux 欢迎来指教&#xff01; 目录 一、什么是权限&#xff1f; 二、权限的本质&#xff1f; 三、Linux中的用户 四、sudo命令 1、什么是sudo 2、 怎么用sudo 3、将普通用户加入sudoer组 &#xff…

Goland GC

Goland GC 引用Go 1.3 mark and sweep 标记法Go 1.5 三色标记法屏障机制插入屏障删除写屏障总结 Go 1.8 混合写屏障(hybrid write barrier)机制总结 引用 https://zhuanlan.zhihu.com/p/675127867 Garbage Collection&#xff0c;缩写为GC&#xff0c;一种内存管理回收的机制…

Android系统不同版本存储权限

一、Android存储简介 Android系统分为内部存储和外部存储 从Android6.0开始不断在更新存储&#xff08;读写&#xff09;权限&#xff0c;除了在AndroidManifest.xml文件里声明&#xff0c;app运行时也要动态申请使用对应的权限 提醒&#xff1a;应用私有存储不需要动态申请权…

计算机组成原理第六章 计算机的运算方法

文章目录 6.1 无符号数和有符号数 6.1.1 无符号数 6.1.2 有符号数 1、原码 2、补码 3、反码 4、移码 5、小结 6.2 数的定点表示和浮点表示 6.2.1 定点表示 6.2.2 浮点表示 1、浮点数的表现形式 2、浮点数的表示范围 3、浮点数的规格化 6.2.3 定点数和浮点数的比…

nmap端口扫描工具——LInux

目录 系统版本: nmap主要功能 安装: nmap命令使用方法

Leetcode - 周赛397

目录 一&#xff0c;3146. 两个字符串的排列差 二&#xff0c;3147. 从魔法师身上吸取的最大能量 三&#xff0c;3148. 矩阵中的最大得分 四&#xff0c;3149. 找出分数最低的排列 一&#xff0c;3146. 两个字符串的排列差 本题就是求同一个字符在两个字符串中的下标之差的…