【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的主…...
深度学习在微纳光子学中的应用
深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向: 逆向设计 通过神经网络快速预测微纳结构的光学响应,替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…...
[2025CVPR]DeepVideo-R1:基于难度感知回归GRPO的视频强化微调框架详解
突破视频大语言模型推理瓶颈,在多个视频基准上实现SOTA性能 一、核心问题与创新亮点 1.1 GRPO在视频任务中的两大挑战 安全措施依赖问题 GRPO使用min和clip函数限制策略更新幅度,导致: 梯度抑制:当新旧策略差异过大时梯度消失收敛困难:策略无法充分优化# 传统GRPO的梯…...
UE5 学习系列(三)创建和移动物体
这篇博客是该系列的第三篇,是在之前两篇博客的基础上展开,主要介绍如何在操作界面中创建和拖动物体,这篇博客跟随的视频链接如下: B 站视频:s03-创建和移动物体 如果你不打算开之前的博客并且对UE5 比较熟的话按照以…...
全球首个30米分辨率湿地数据集(2000—2022)
数据简介 今天我们分享的数据是全球30米分辨率湿地数据集,包含8种湿地亚类,该数据以0.5X0.5的瓦片存储,我们整理了所有属于中国的瓦片名称与其对应省份,方便大家研究使用。 该数据集作为全球首个30米分辨率、覆盖2000–2022年时间…...
《用户共鸣指数(E)驱动品牌大模型种草:如何抢占大模型搜索结果情感高地》
在注意力分散、内容高度同质化的时代,情感连接已成为品牌破圈的关键通道。我们在服务大量品牌客户的过程中发现,消费者对内容的“有感”程度,正日益成为影响品牌传播效率与转化率的核心变量。在生成式AI驱动的内容生成与推荐环境中࿰…...
Spring Boot面试题精选汇总
🤟致敬读者 🟩感谢阅读🟦笑口常开🟪生日快乐⬛早点睡觉 📘博主相关 🟧博主信息🟨博客首页🟫专栏推荐🟥活动信息 文章目录 Spring Boot面试题精选汇总⚙️ **一、核心概…...
令牌桶 滑动窗口->限流 分布式信号量->限并发的原理 lua脚本分析介绍
文章目录 前言限流限制并发的实际理解限流令牌桶代码实现结果分析令牌桶lua的模拟实现原理总结: 滑动窗口代码实现结果分析lua脚本原理解析 限并发分布式信号量代码实现结果分析lua脚本实现原理 双注解去实现限流 并发结果分析: 实际业务去理解体会统一注…...
ElasticSearch搜索引擎之倒排索引及其底层算法
文章目录 一、搜索引擎1、什么是搜索引擎?2、搜索引擎的分类3、常用的搜索引擎4、搜索引擎的特点二、倒排索引1、简介2、为什么倒排索引不用B+树1.创建时间长,文件大。2.其次,树深,IO次数可怕。3.索引可能会失效。4.精准度差。三. 倒排索引四、算法1、Term Index的算法2、 …...
Spring Boot+Neo4j知识图谱实战:3步搭建智能关系网络!
一、引言 在数据驱动的背景下,知识图谱凭借其高效的信息组织能力,正逐步成为各行业应用的关键技术。本文聚焦 Spring Boot与Neo4j图数据库的技术结合,探讨知识图谱开发的实现细节,帮助读者掌握该技术栈在实际项目中的落地方法。 …...
GitHub 趋势日报 (2025年06月08日)
📊 由 TrendForge 系统生成 | 🌐 https://trendforge.devlive.org/ 🌐 本日报中的项目描述已自动翻译为中文 📈 今日获星趋势图 今日获星趋势图 884 cognee 566 dify 414 HumanSystemOptimization 414 omni-tools 321 note-gen …...
