【C++】string类的接口综合运用
目录
介绍:
一,string对象的构建
二,string类对象的容量操作
介绍:
string容器我们之前已经粗略了解了基本增添、修改、删除、插入等基本功能,这里就不再做过多说明,接下来我们全面并详细讲解STL容器中string的使用。
一,string对象的构建
string对象的构建公有多种方法,这里我们先掌握以下六种方法即可:
函数名称 | 功能说明 | 样例 |
string(); | 构造空的string类对象,即空字符串 | 第一种方式:string s1; 第二种方式:string s2(""); |
string(const string& str); | 拷贝构造函数,直接拷贝 | string s1; string s2(s1); |
string(const string& str, size_t pos, size_t len = npos); | 复制str,从字符位置pos开始,复制len个字符,如果str太短,则直接将str全部复制 | string s1("hello world"); string s2(s1, 1, 6); |
string(const char* s); | 复制由s指向的串 | string s2("hello world"); |
string(const char* s, size_t n); | 从由s指向的字符数组中复制前n个字符 | string s1("hello world"); string s2(s1, 5); |
string(size_t n, char c); | 复制n个字符c | string s1(10, 'x'); |
以上只是我们常用的构建方法,要想查看所有的构建方法可点击此链接:constructor
二,string类对象的容量操作
string容器的语法操作:
C++内部给我们提供了很多的语法操作,下面是我们常用的容器操作。
函数名称(链接形式查看) | 功能说明 | 样例 |
size | 返回字符串有效字符长度 | string s = "abcde"; 输出5 |
length | 返回字符串有效字符长度 | string s = "abcde"; 不能length(s) 输出5 |
capacity | 返回空间总大小 | string s = "abcde"; 只能s.capacity() 不能capacity(s) 输出大于等于5的数字 |
empty | 检测字符串释放为空串,是返回true,否则返回false | string s = "abcde"; s.empty()或empty(s) 输出0 |
reserve | 为字符串预留更大的空间。 它会将容量扩到指定数字或者更大,但它不能缩小容量 | string s = "abcde"; s.reserve(2); 容量不变,不会减小 s.reserve(20); 容量大于等于20 |
resize | 调整字符串长度为n,多出的空间用字符c填充,没有c时 '\0' 填充 | string s = "abcde"; s.resize(2); 此时s = "ab" s.resize(10, 'x'); 此时s = "abxxxxxxxx" |
clear | 清空所有有效字符 | string s = "abcde"; 只能s.clear(); 不能clear(s); 此时s为空串 |
这里我们再对之前讲的 insert 进行补充和 erase 说明,可点击链接进行查看,这里就不做过多说明。
注意:
1. size()与length()方法底层实现原理完全相同,引入size()的原因是为了与其他容器的接口保持一致,一般情况下基本都是用size()。
2. clear()只是将string中有效字符清空,不改变底层空间大小,即不改变容量。
3. resize有resize(size_t n) 和 resize(size_t n, char c)两种形式,这两种形式都是将字符串有效字符个数改变到n个,不同的是当字符个数增多时:resize(n)用0来填充多出的元素空间,resize(size_t n, char c)用字符c来填充多出的元素空间。还有,resize在改变元素个数时,如果是将元素个数增多,可能会改变底层容量的大小,如果是将元素个数减少,底层空间总大小不变。
4. reserve(size_t n = 0)只是为string预留空间,它不改变有效元素个数,当reserve的参数小于string的底层空间总大小时,reserver不会改变容量大小。
string容器的遍历和访问操作:
在容器中,我们即可使用普通的方法进行遍历,也可使用迭代器进行遍历,前期可认为迭代器如同指针。以下是常用的容器遍历和访问方法。
函数名称(链接形式查看) | 功能说明 | 样例 |
operator[] | 运用“ [] ” 重载运算符,运用数组的形式进行访问 | string s = "abcde" s[i]或s.operator[](i) 访问第i个下标的元素 |
at | at访问下标的形式访问对应的元素 | string s = "abcde" s.at(i)访问第i个下标的元素 |
begin + end | begin 和 end返回正向迭代器(迭代器iterator用法像指针) begin获取一个字符的迭代器 end获取最后一个字符下一个位置的迭代器 正向迭代器向前迭代:增加它们会使它们朝向字符串的结尾移动 | string s = "abcde" string::iterator it = s.begin() it指向开头元素的迭代器 string::iterator it = s.end() it指向最后一个元素下一 个位置的迭代器 |
rbegin + rend | rbegin 和 rend返回反向迭代器 rbegin指向字符串的最后一个字符(即反向开始) rend指向字符串第一个字符之前的理论元素 反向迭代器向后迭代:增加它们会使它们朝向字符串的开始移动 | string s = "abcde" string::reverse_iterator it = s.rbegin() it指向最后一个字符的迭代器 string::reverse_iterator it = s.rbegin() it指向第一个字符之前的迭代器 |
范围for | C++11标准的创新方式,与普通for的用法相同 | string s = "abcde" for (auto ch : s) { } 将s赋给ch,自动往下走 自动判断结束 |
注意:下标+[]的使用只适用于部分容器,底层物理有一定连续链式结构、树形、哈希结构等就不能使用 “ [] ” 形式访问,只能用迭代器进行访问。因此,迭代器才是容器访问的根本。
代码演示:
#include <iostream>
#include <string>
using namespace std;
int main()
{
string s = "abcde";
for (auto e : s) { //范围for的使用
cout << e;//依次输出abcde
}//正向迭代器的使用
for (string::iterator it = s.begin(); it != s.end(); it++) {
cout << *it;//依次输出abcde
}//反向迭代器的使用
for (string::reverse_iterator it = s.rbegin(); it != s.rend(); it++) {
cout << *it;//输出edcba
}const string s1("abc");
//const形式写法的正向迭代器
for (string::const_iterator it = s1.begin(); it != s1.end(); it++) {
cout << *it;
}
//const形式写法的反向迭代器
for (string::const_reverse_iterator it = s1.rbegin(); it != s1.rend(); it++) {
cout << *it;
}
return 0;
}
注意:迭代器 const_iterator it 本质保护迭代器指向的数据不能修改,即 *it 不能修改。迭代器const iterator it 保护迭代器本身不能修改,即 it 不能修改。因此在const修饰的串中,要用const_iterator it 或 const_reverse_iterator it 的方式进行迭代使用。
string类对象的修改操作
有些操作的基础功能之前有过说明,这里我们简单说明一下,有些功能需注意。
函数名称(链接形式查看) | 功能说明 |
back | 返回字符串最后一个字符的引用 该函数不得在空字符串上调用 |
font | 返回字符串第一个字符的引用 该函数不得在空字符串上调用 |
push_back | 将字符c追加到字符串末尾,长度增加1 |
append | 之前有过说明,在当前串的末尾追加其他字符或串 |
operator+= | 与append功能相似 |
c_str | 返回C格式 const char* const 类型的指针,即将string转换为char*型 |
find + npos | find是用来正向查找 查找与string串第一次匹配的串,返回在string串中的位置 如果没有找到匹配项,该函数将返回string::npos npos是size_t类型元素可能具有的最大值的静态成员常量值,即-1 |
rfind + npos | rfind用来反向查找,即逆序 查找与string串最后一次匹配的串,返回在string串中的位置 如果没有找到匹配项,该函数将返回string::npos |
substr | 在str中从pos位置开始,截取n个字符,然后将其返回。 |
注意:
1. 在string尾部追加字符时,s.push_back(c) / s.append(1, c) / s += 'c'三种的实现方式差不 多,一般况下string类的 += 操作用的比较多, += 操作不仅可以连接单个字符,还可以连接字符串
2. 在append的用法 string& append(const char* s, size_t n) 中,是在末尾追加s的前n个字符。在string& append(const string& s, size_t n) 中,是在末尾追加s的第n个下标起,一直到末尾。补:在许多的插入操作中都是一样的操作,如assign等。
3. npos是size_t类型元素可能具有的最大值的静态成员常量值,而无符号整数类型size_t可表示的最大数值是以 -1 在内存中存储。当用作字符串成员函数中的len(或sublen)参数的值时,该值表示 “直到字符串末尾”。当作为返回值时,它通常用于表示没有匹配项。
4. 在点击链接产看详细文档功能时要注意 const string& str 与 const char* s 两种形式,有时形式不一样会产生不同的功能,如上面提过的assign、append等,有时需要运用 c_str 将 const string& 型转化为const char* 型来进行C语言中字符串的使用,如文件FILE、C语言中的字符串用法等。
5. 像容器内部的很多接口,如find、assign、append、insert、erase等,如果没有指定有关 “长度” 的参数,那么将默认遍历直到结束。
代码演示(1):
#include <iostream>
#include <string>
using namespace std;
int main()
{
string s = "abc";//const char* p = s;//s是string类型,不是const char*型,出错
const char* p = s.c_str();//c._str将其转换const char*
s.back() = 'q';
s.front() = 'A';
cout << s << endl;//输出Abqs += "eee";
s += 'e';
s.operator+=("asca");//运用 += 的函数形式string s1("");
s1.append("qwert", 2);//追加前两个字符到s1
s1.clear();
string s2("qwert");
s1.append(s2, 2);//追加s2的第二个下标起一直到末尾到s1
//下面的assign复制的运用跟append的情况一样
string s3 = "abcdefg";
string s4;
s4.assign(s3, 3);
cout << s4 << endl;
s4.assign("abcdefg", 3);
cout << s4;
return 0;
}
代码演示(2):
#include <iostream>
#include <string>
using namespace std;
int main()
{
string s("string");
const char* p = s.c_str();
cout << s.c_str() << endl;string s("https://string/refer/string/http");
size_t n = s.find("string");//从s串的开头遍历,返回与"string"第一次匹配的下标
//size_t n = s.rfind("string");//从s串的开头遍历,返回与"string"最后一次匹配的下标
cout << n << endl;size_t ps = s.find("string", 9);//从第9个下标起往后搜索与"string"第一次匹配的下标位置
//size_t ps = s.rfind("string", 10);//搜索从开头起到第10个下标,忽略第10个下标往后的匹配
cout << ps << endl;size_t np = s.find("string", 10, 6);//从第10个下标开始搜索,指定要搜索的长度为6
//size_t np = s.rfind("string", 10, 6);//搜索从开头到第10个下标,指定要搜索的长度为6
cout << np << endl;string p = s.substr(2, 6);//从s的第2个下标位置开始,截取6个字符,然后返回
cout << p << endl;
return 0;
}
string类非成员函数
函数(链接形式查看) | 功能说明 |
operator+ | ' + ' 符号的重载,此功能尽量少用,因为是传值返回,导致深拷贝效率低 |
operator>> | 输入运算符重载 |
operator<< | 输出运算符重载 |
getline | 获取一行字符串,可输入空格字符,与流提取不同的是流提取默认使用空格作为分隔符,只能提取单个数据,而getline一次提取一行文本,即遇到换行才结束 |
relational operators | 字符串的大小比较,封装了比较串的用法 即:对“ > ”、“ < ”、“ == ”、“ != ”、“ >= ”、“ <= ” 操作符进行重载 |
上面的几个常用接口大家深入学习下。在string类中还有一些其它很多操作,这里就不一一列举,大家在有需要的时候可查看以下链接文档。
string的类功能大全
相关文章:
【C++】string类的接口综合运用
目录 介绍: 一,string对象的构建 二,string类对象的容量操作 介绍: string容器我们之前已经粗略了解了基本增添、修改、删除、插入等基本功能,这里就不再做过多说明,接下来我们全面并详细…...

分布式ID生成框架Leaf升级踩坑
背景: 在项目中需要一个统一的拿单号等唯一ID的服务,就想起了之前用到的leaf,但是因为项目要求,leaf的版本不符合,需要做一些升级 项目地址:https://github.com/Meituan-Dianping/Leaf 升级点࿱…...

常用的设计模式
文章目录 常用的设计模式:一、单例模式3、懒汉式 - 懒汉式非线程安全4、饿汉式 - 线程安全5、懒汉式和饿汉式区别6、双重检查锁定7、应用场景 二、工厂模式1、简单工厂模式2、工厂模式3、抽象工厂4、总结 三、代理模式1、静态代理2、动态代理jdk自带动态代理 3、Cgl…...

git的相关实用命令
参看文章:https://blog.csdn.net/qq_21688871/article/details/130158888 http://www.mobiletrain.org/about/BBS/159885.html 1、git commit后,但发现文件有误,不想push(提交到本地库,回退到暂存区) git reset --sof…...
【使用`model.status`来获取gurobi求解过程中的模型状态】
在Gurobi中,你可以使用model.status来获取求解过程中的模型状态。可以使用了model.status来检查模型是否找到最优解。模型状态是一个Gurobi的常量,表示了求解过程中的不同状态。 以下是一些常见的模型状态: GRB.OPTIMAL: 最优解被找到。GRB…...
【UGUI】Unity教程:实现物品的拖拽功能
大家好,今天,我们将一起学习如何在Unity中实现物品的拖拽功能。这是一个非常实用的技能,无论你是在制作RPG游戏的背包系统,还是在制作策略游戏的建筑放置功能,都会用到这个技能。那么,让我们开始吧…...
【奇淫技巧】两数交换
【奇淫技巧】两数交换 临时变量法:借助中间变量加减法:不使用中间变量异或法:不使用中间变量语法糖:某些编程语言支持交换语法糖借助函数,不交换 前提:待交换的两个元素,分别用a,b表示…...

Java核心知识点整理大全26-笔记
目录 27. Storm 7.1.1. 概念 27.1.1. 集群架构 27.1.1.1. Nimbus(master-代码分发给 Supervisor) 27.1.1.2. Supervisor(slave-管理 Worker 进程的启动和终止) 27.1.1.3. Worker(具体处理组件逻辑的进程ÿ…...

“上云”还是“下云”?探云计算的下一站未来!
引言 10 月 27 日,X(原Twitter)工程技术发布帖子称,在过去的一年里,技术团队优化了 X 的云服务使用方式,着手将更多工作负载迁往本地基础设施。这一转变使 X 每月的云成本降低了 60%。所有媒体、Blob 存储均…...

Linux中top命令输出日志分析?
以下是对输出的各部分的解释: 09:54:34:系统当前时间。up 161 days, 2:08:系统已经运行了161天2小时8分钟。5 users:有5个用户登录系统。load average: 0.13, 0.08, 0.05:系统的1分钟、5分钟、15分钟的平均负载。负载…...

执行栈和执行上下文
前端面试大全JavaScript执行栈和执行上下文 🌟经典真题 🌟执行上下文 🌟栈数据结构 🌟执行上下文生命周期 🌟真题解答 🌟总结 🌟经典真题 谈谈你对 JavaScript 执行上下文栈理解 &#…...

7、单片机与W25Q128(FLASH)的通讯(SPI)实验(STM32F407)
SPI接口简介 SPI 是英语Serial Peripheral interface的缩写,顾名思义就是串行外围设备接口。是Motorola首先在其MC68HCXX系列处理器上定义的。 SPI,是一种高速的,全双工,同步的通信总线,并且在芯片的管脚上只占用四根…...

stream流和方法引用
1.Stream流 1.1体验Stream流【理解】 案例需求 按照下面的要求完成集合的创建和遍历 创建一个集合,存储多个字符串元素把集合中所有以"张"开头的元素存储到一个新的集合把"张"开头的集合中的长度为3的元素存储到一个新的集合遍历上一步得到的集…...

Redis——某马点评day01——短信登录
项目介绍 导入黑马点评项目 项目架构 基于Session实现登录 基本流程 实现发送短信验证码功能 controller层中 /*** 发送手机验证码*/PostMapping("code")public Result sendCode(RequestParam("phone") String phone, HttpSession session) {// 发送短信…...

AES加密技术:原理与应用
一、引言 随着信息技术的飞速发展,数据安全已成为越来越受到重视的领域。加密技术作为保障数据安全的重要手段,在信息安全领域发挥着举足轻重的作用。AES(Advanced Encryption Standard)作为一种对称加密算法,自1990年…...
Unity中PlayerPrefs在PC上存储位置总结
编辑器下和EXE存储位置是不同的,这也不难理解,是为了避免存储位置相同导致开发和测试冲突。 编辑器下位置:HKEY_CURRENT_USER\Software\Unity\UnityEditor\ExampleCompanyName\ExampleProductName EXE位置:HKEY_CURRENT_USER\Sof…...
消融实验:深度学习的关键分析工具
消融实验:深度学习的关键分析工具 在深度学习和机器学习领域,消融实验(Ablation Study)是一种重要的实验方法,用于理解和评估模型的各个组成部分对其整体性能的贡献。通过这种方法,研究人员可以更深入地了…...

Redis缓存——Spring Cache入门学习
Spring Cache 介绍 Spring Cache 是一个框架,实现了基于注解的缓存功能,只需要简单地加一个注解,就能实现缓存功能。 Spring Cache 提供了一层抽象,底层可以切换不同的缓存实现,例如: EHCacheCaffeineR…...

Python标准库copy【侯小啾python领航班系列(十五)】
Python标准库copy【侯小啾python领航班系列(十五)】 大家好,我是博主侯小啾, 🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹…...

Android--Jetpack--Lifecycle详解
富贵本无根,尽从勤里得 一,定义 Lifecycle 是一个具备宿主生命周期感知能力的组件。它持有组件(Activity/Fragment)生命周期状态信息,并且允许其观察者监听宿主生命周期状态变化。 顾名思义,Lifecycle的主…...

K8S认证|CKS题库+答案| 11. AppArmor
目录 11. AppArmor 免费获取并激活 CKA_v1.31_模拟系统 题目 开始操作: 1)、切换集群 2)、切换节点 3)、切换到 apparmor 的目录 4)、执行 apparmor 策略模块 5)、修改 pod 文件 6)、…...

[ICLR 2022]How Much Can CLIP Benefit Vision-and-Language Tasks?
论文网址:pdf 英文是纯手打的!论文原文的summarizing and paraphrasing。可能会出现难以避免的拼写错误和语法错误,若有发现欢迎评论指正!文章偏向于笔记,谨慎食用 目录 1. 心得 2. 论文逐段精读 2.1. Abstract 2…...

[10-3]软件I2C读写MPU6050 江协科技学习笔记(16个知识点)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16...

PL0语法,分析器实现!
简介 PL/0 是一种简单的编程语言,通常用于教学编译原理。它的语法结构清晰,功能包括常量定义、变量声明、过程(子程序)定义以及基本的控制结构(如条件语句和循环语句)。 PL/0 语法规范 PL/0 是一种教学用的小型编程语言,由 Niklaus Wirth 设计,用于展示编译原理的核…...

Android15默认授权浮窗权限
我们经常有那种需求,客户需要定制的apk集成在ROM中,并且默认授予其【显示在其他应用的上层】权限,也就是我们常说的浮窗权限,那么我们就可以通过以下方法在wms、ams等系统服务的systemReady()方法中调用即可实现预置应用默认授权浮…...
css3笔记 (1) 自用
outline: none 用于移除元素获得焦点时默认的轮廓线 broder:0 用于移除边框 font-size:0 用于设置字体不显示 list-style: none 消除<li> 标签默认样式 margin: xx auto 版心居中 width:100% 通栏 vertical-align 作用于行内元素 / 表格单元格ÿ…...

selenium学习实战【Python爬虫】
selenium学习实战【Python爬虫】 文章目录 selenium学习实战【Python爬虫】一、声明二、学习目标三、安装依赖3.1 安装selenium库3.2 安装浏览器驱动3.2.1 查看Edge版本3.2.2 驱动安装 四、代码讲解4.1 配置浏览器4.2 加载更多4.3 寻找内容4.4 完整代码 五、报告文件爬取5.1 提…...

图表类系列各种样式PPT模版分享
图标图表系列PPT模版,柱状图PPT模版,线状图PPT模版,折线图PPT模版,饼状图PPT模版,雷达图PPT模版,树状图PPT模版 图表类系列各种样式PPT模版分享:图表系列PPT模板https://pan.quark.cn/s/20d40aa…...

【 java 虚拟机知识 第一篇 】
目录 1.内存模型 1.1.JVM内存模型的介绍 1.2.堆和栈的区别 1.3.栈的存储细节 1.4.堆的部分 1.5.程序计数器的作用 1.6.方法区的内容 1.7.字符串池 1.8.引用类型 1.9.内存泄漏与内存溢出 1.10.会出现内存溢出的结构 1.内存模型 1.1.JVM内存模型的介绍 内存模型主要分…...
关于uniapp展示PDF的解决方案
在 UniApp 的 H5 环境中使用 pdf-vue3 组件可以实现完整的 PDF 预览功能。以下是详细实现步骤和注意事项: 一、安装依赖 安装 pdf-vue3 和 PDF.js 核心库: npm install pdf-vue3 pdfjs-dist二、基本使用示例 <template><view class"con…...