【C++庖丁解牛】实现string容器的增删查改 | string容器的基本接口使用


📙 作者简介 :RO-BERRY
📗 学习方向:致力于C、C++、数据结构、TCP/IP、数据库等等一系列知识
📒 日后方向 : 偏向于CPP开发以及大数据方向,欢迎各位关注,谢谢各位的支持


请添加图片描述


目录

  • 前言
  • 📖push_back接口
  • 📖append接口
  • 📖operator+= (重点)
  • 📖replace接口
  • 📖find接口
  • 📖npos
  • 📖find + npos(重点)
  • 📖substr
  • 📖insert接口
  • 📖erase接口
  • 📖refind接口
  • 📖c_str接口
  • 📖find_first_of接口
  • 📖compare接口
  • 总结


前言

函数名称功能说明
push_back在字符串后尾插字符c
append在字符串后追加一个字符串
operator+= (重点)在字符串后追加字符串str
c_str(重点)返回C格式字符串
find + npos(重点)从字符串pos位置开始往后找字符c,返回该字符在字符串中的位置
rfind从字符串pos位置开始往前找字符c,返回该字符在字符串中的位置
substr在str中从pos位置开始,截取n个字符,然后将其返回

📖push_back接口

int main()
{string str;str.push_back(' ');   // 在str后插入空格str.append("hello");  // 在str后追加一个字符"hello"str += 'w';           // 在str后追加一个字符'w'   str += "xxx";          // 在str后追加一个字符串"xxx"cout << str << endl;cout << str.c_str() << endl;   // 以C语言的方式打印字符串return 0;
}

在这里插入图片描述


📖append接口

append()是一个成员函数,用于将字符串或字符序列添加到当前字符串的末尾。它有多种重载形式,可以接受不同类型的参数。

在这里插入图片描述
这里其实用第一个就已经足够了,其他的显的有些多余

  1. 传入一个字符串作为参数,它会将该字符串的内容添加到当前字符串的末尾。
int main()
{string s1("hello");s1.append("abcd");cout << s1 << endl;return 0;
}

在这里插入图片描述

  1. 如果传入一个字符数组作为参数,它会将该字符数组的内容添加到当前字符串的末尾。
string str = "Hello";
char arr[] = " World";
str.append(arr);
// 现在str的值为"Hello World"
  1. 如果传入一个字符和重复次数作为参数,它会将该字符重复指定次数后添加到当前字符串的末尾
string str = "Hello";
char ch = '!';
int repeatCount = 3;
str.append(repeatCount, ch);
// 现在str的值为"Hello!!!"

4.如果传入字符串的头和尾作为参数,它会将该字符添加到当前字符串的末尾

int main()
{string s1("hello");s1.append("abcd");cout << s1 << endl;//在s2后面加入s1string s2 = "xxxx";s2.append(s1.begin(), s1.end());cout << s2 << endl;return 0;
}

📖operator+= (重点)

int main()
{//最简便的方式string s1("hello");string s2 = "xxxx";s1 += '!';cout << s1 << endl;s1 += "world";cout << s1 << endl;s1 += s2;cout << s1 << endl;return 0;
}

在这里插入图片描述


📖replace接口

string容器的replace接口用于替换字符串中的一部分内容。它有多个重载形式,可以根据需要进行不同的替换操作。

  1. replace(pos, count, str):将从位置pos开始的count个字符替换为字符串str。
    示例:string str = “Hello, world!”;
    str.replace(7, 5, “CSDN”);
    替换后的字符串为:“Hello, CSDN!”
  1. replace(pos, count, str, pos2, count2):将从位置pos开始的count个字符替换为字符串str中从位置pos2开始的count2个字符。
    示例:string str = “Hello, world!”;
    string str2 = “CSDN”;
    str.replace(7, 5, str2, 0, 4);
    替换后的字符串为:“Hello, CSDN!”
  1. replace(iterator1, iterator2, str):将迭代器iterator1和iterator2之间的字符替换为字符串str。
    示例:string str = “Hello, world!”;
    string str2 = “CSDN”;
    str.replace(str.begin() + 7, str.begin() + 12, str2);
    替换后的字符串为:“Hello, CSDN!”
  1. replace(iterator1, iterator2, iterator3, iterator4):将迭代器iterator1和iterator2之间的字符替换为迭代器iterator3和iterator4之间的字符。
    示例:string str = “Hello, world!”;
    string str2 = “CSDN”;
    str.replace(str.begin() + 7, str.begin() + 12, str2.begin(), str2.end());
    替换后的字符串为:“Hello, CSDN!”

📖find接口

string容器的find接口用于在字符串中查找指定的子串,并返回其第一次出现的位置。该接口有多个重载形式,可以根据需要选择使用。

  1. find(const string& str, size_t pos = 0) const:
    在字符串中从指定位置pos开始查找子串str,并返回其第一次出现的位置。如果找不到,则返回string::npos。
  1. find(const char* s, size_t pos = 0) const:
    在字符串中从指定位置pos开始查找C风格字符串s,并返回其第一次出现的位置。如果找不到,则返回string::npos。
  1. find(char c, size_t pos = 0) const:
    在字符串中从指定位置pos开始查找字符c,并返回其第一次出现的位置。如果找不到,则返回string::npos。

其中,pos参数表示查找的起始位置,默认为0,即从字符串的开头开始查找。


📖npos

string::npos是C++中string类的一个静态成员变量,它表示一个无效的或者不存在的位置。在string类中,npos的值是一个特殊的常量,通常被用来表示字符串中某个字符或子串不存在的情况。

当我们在使用string类的成员函数进行查找操作时,如果没有找到指定的字符或子串,那么返回值就会是npos。这个值在不同的编译器中可能会有所不同,但通常它的值是-1或者一个非法的索引值。
使用npos可以方便地判断字符串中是否包含某个字符或子串。


📖find + npos(重点)

int main()
{string s1("hello world hello world");cout << s1 << endl;//将所有的空格替换成20%size_t pos = s1.find(' ');while (pos != string::npos){s1.replace(pos, 1, "%20"); //replace效率是特别低的最好不要用pos = s1.find(' ');}cout << s1 << endl;return 0;
}

在这里插入图片描述


📖substr

substr是一种字符串操作函数,用于从一个字符串中提取子字符串。它的语法如下:
string substr (size_t pos, size_t len) const;
其中,pos表示要提取的子字符串的起始位置,len表示要提取的子字符串的长度。返回值是一个新的字符串,包含了从原始字符串中提取的子字符串。

获取file的后缀

int main() 
{string file("string.cpp");size_t pos = file.rfind('.');string suffix(file.substr(pos, file.size() - pos)); //取后缀并拷贝构造suffixcout << suffix << endl;return 0;
}

在这里插入图片描述
取出url中的域名

int main() 
{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 1;}start += 3;size_t finish = url.find('/', start);string address = url.substr(start, finish - start);cout << address << endl;return 0;
}

在这里插入图片描述


📖insert接口

string容器的insert接口用于在指定位置插入字符或字符串。它有多个重载形式,具体取决于插入的内容和位置。

  1. insert(pos, str):在指定位置pos前插入字符串str。
    示例:str.insert(3, "hello") 将在索引为3的位置前插入字符串"hello"。

2. insert(pos, str, subpos, sublen):在指定位置pos前插入字符串str的子串,子串的起始位置为subpos,长度为sublen
示例:str.insert(5, "world", 2, 3) 将在索引为5的位置前插入字符串"wor"。

  1. insert(pos, n, ch):在指定位置pos前插入字符ch的副本,重复插入n次。
    示例:str.insert(2, 3, 'a') 将在索引为2的位置前插入3个字符’a’。

📖erase接口

string容器的erase接口用于删除指定位置的字符或者一段字符。它有两种重载形式:

erase(pos, count):删除从位置pos开始的count个字符。其中,pos是一个索引值,表示要删除的起始位置;count是要删除的字符数量。

erase(iterator first, iterator last):删除从迭代器first指向的字符开始,到迭代器last指向的字符之前的所有字符。其中,first和last是迭代器,表示要删除的字符范围。

需要注意的是,erase操作会改变原始字符串,删除指定位置的字符后,后面的字符会自动向前移动。


📖refind接口

与find()函数类似,但是从字符串的末尾开始查找子串

size_t refind(const string& str, size_t pos = 0) const;
其中,str是要查找的子串,pos是查找的起始位置,默认为0。该函数返回子串第一次出现的位置,如果找不到则返回string::npos。

使用示例:

#include <iostream>
#include <string>
using namespace std;int main() {string str = "Hello, world!";string subStr = "world";size_t pos = str.find(subStr);if (pos != string::npos) {cout << "子串 \"" << subStr << "\" 在字符串 \"" << str << "\" 中的位置是:" << pos << endl;}else {cout << "未找到子串 \"" << subStr << "\" 在字符串 \"" << str << "\" 中" << endl;}return 0;
}

在这里插入图片描述


📖c_str接口

c_str()是C++中的一个字符串成员函数,用于返回一个指向以null结尾的字符数组(C风格字符串)的指针。它通常用于将C++的std::string对象转换为C风格字符串。
使用c_str()函数可以方便地将std::string对象传递给需要C风格字符串作为参数的函数或接口。

例如,如果你有一个std::string对象str,你可以通过调用str.c_str()来获取一个指向以null结尾的字符数组的指针。

需要注意的是:c_str()返回的指针指向的字符数组是只读的,不能修改其中的内容。如果需要修改字符串内容,应该使用其他方法。

📖find_first_of接口

string容器的find_first_of()函数是用于在字符串中查找第一个与指定字符序列中的任何字符匹配的字符的位置。它的语法如下:

size_t find_first_of(const string& str, size_t pos = 0) const noexcept;

其中,str是要查找的字符序列,pos是开始查找的位置,默认为0。
该函数返回一个size_t类型的值,表示找到的字符的位置。如果未找到匹配的字符,则返回string::npos。
该函数会从字符串的pos位置开始逐个字符地与str中的字符进行匹配,直到找到第一个匹配的字符或者到达字符串的末尾。

将语句中的“aeiou”全部替换成“ * ”

#include <iostream>       // std::cout
#include <string>         // std::string
#include <cstddef>        // std::size_tint main()
{std::string str("Please, replace the vowels in this sentence by asterisks.");std::size_t found = str.find_first_of("aeiou");while (found != std::string::npos){str[found] = '*';found = str.find_first_of("aeiou", found + 1);  }std::cout << str << '\n';return 0;
}

在这里插入图片描述

📖compare接口

string容器的compare()函数是用于比较两个字符串的。它返回一个整数值,表示两个字符串的大小关系。
compare()函数有以下几种用法:

1. compare(str):将当前字符串与参数str进行比较。返回值为0表示两个字符串相等,返回值大于0表示当前字符串大于参数str,返回值小于0表示当前字符串小于参数str。
2. compare(pos, len, str):从当前字符串的位置pos开始,比较长度为len的子串与参数str进行比较。返回值的含义与上述相同。
3. compare(pos, len, str, subpos, sublen):从当前字符串的位置pos开始,比较长度为len的子串与参数str的子串(从subpos开始,长度为sublen)进行比较。返回值的含义与上述相同。

注意,compare()函数是区分大小写的,即大写字母和小写字母被认为是不同的字符。

#include <iostream>
#include <string>int main()
{std::string str1("green apple");std::string str2("red apple");if (str1.compare(str2) != 0)std::cout << str1 << " is not " << str2 << '\n';if (str1.compare(6, 5, "apple") == 0)std::cout << "still, " << str1 << " is an apple\n";if (str2.compare(str2.size() - 5, 5, "apple") == 0)std::cout << "and " << str2 << " is also an apple\n";if (str1.compare(6, 5, str2, 4, 5) == 0)std::cout << "therefore, both are apples\n";return 0;
}

在这里插入图片描述

总结

在这里只是着重进行了string容器的常用接口的介绍以及使用,更多的接口还需要去查阅,修行之路还很漫长,让我们共同努力

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/734131.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MACBOOK PRO M2 MAX 安装Stable Diffusion及文生图实例

以前偶尔会使用Midjourney生成一些图片&#xff0c;现在使用的头像就是当时花钱在Midjourney上生成的。前段时间从某鱼上拍了一台性价比还不错的macbook&#xff0c;想着不如自己部署Stable Diffusion&#xff08;以下简称SD&#xff09;尝试一下。 网上有很多教程&#xff0c…

业务能力技术栈 —— 树立层次思维,专注于本层面的事物

Q:根据目前的物理学&#xff0c;世间万物是由夸克等基本粒子构成的&#xff0c;会有人想从基本粒子推演出万物的运行规律吗&#xff1f;如社会规律&#xff0c;历史规律&#xff0c;即便是考虑了量子力学的概率与不确定性。 肯定有人想&#xff0c;但是目前做不到&#xff0c;不…

ES6语法(七)Promise

1. Promise ECMAscript 6 原生提供了 Promise 对象。Promise 对象代表了未来将要发生的事件&#xff0c;用来传递异步操作的消息。 1.1. 说明 1.1.1. 单个异步程序 //检测机构//resolve : 表示成功的状态//reject : 表示失败的状态new Promise((resolve,reject) > {if(处理…

Apache POI 解析和处理Excel

摘要&#xff1a;由于开发需要批量导入Excel中的数据&#xff0c;使用了Apache POI库&#xff0c;记录下使用过程 1. 背景 Java 中操作 Excel 文件的库常用的有Apache POI 和阿里巴巴的 EasyExcel 。Apache POI 是一个功能比较全面的 Java 库&#xff0c;适合处理复杂的 Offi…

机器学习(2_1)经验误差,拟合度,评估方法

前言 大部分概念都会给出解释&#xff0c;如果你有不懂的概念&#xff0c;请你在评论中写出 训练集&#xff08;Training Set&#xff09; 用于模型拟合的数据样本。这部分数据集主要用于训练模型&#xff0c;使模型通过学习数据的特征来产生一个可以用于预测的模型。在训练…

来,聊聊前端框架发展史

文章目录 前言一、阶段1. 早期阶段&#xff1a;原生HTML/CSS/JavaScript2. jQuery时代3. MVC/MVVM框架的兴起4. 现代前端框架与工具链4.1. React Webpack Babel4.1.1. 安装依赖4.1.2. 配置Webpack4.1.3. Babel配置4.1.4. React组件和入口文件4.1.5. 运行开发服务器 4.2. Vue.…

qt-C++笔记之使用Cmake来组织和构建QWidget工程项目

qt-C笔记之使用Cmake来组织和构建QWidget工程项目 —— 杭州 2024-03-10 code review! 文章目录 qt-C笔记之使用Cmake来组织和构建QWidget工程项目1.运行2.文件结构3.CMakeLists.txt4.main.cpp5.widget.h6.widget.cpp7.widget.ui 1.运行 2.文件结构 3.CMakeLists.txt 代码 c…

中国联通云联网在多元行业应用中的核心地位与价值体现

在全球化浪潮与数字化转型的时代背景下&#xff0c;中国联通积极响应市场需求&#xff0c;推出以云联网为核心的全球化智能组网解决方案&#xff0c;突破地理限制&#xff0c;为各行业提供高效、安全、灵活的网络服务。该方案不仅涵盖传统的通信连接&#xff0c;更是深入到能源…

day54(reactJS)关于事件处理函数 props方法 合成事件 严格模式 组件声明周期 纯组件以及性能优化以及网络请求

&#xff08;reactJS&#xff09;关于事件处理函数this指向的 props与state&#xff0c;setState方法 合成事件与事件对象 严格模式标签 组件声明周期 纯组件以及性能优化以及关于网络请求 1.关于事件处理函数this指向2.关于合成事件与事件对象3.props与state&#xff0c;setSt…

【神经网络与深度学习】深度神经网络(DNN)

概述 深度神经网络&#xff08;Deep Neural Networks&#xff0c;DNN&#xff09;是一种由多个隐藏层组成的神经网络模型。每个隐藏层由多个神经元组成&#xff0c;这些神经元通过权重和激活函数进行信息传递和计算。 深度神经网络通过多层的非线性变换&#xff0c;可以学习到…

数据结构---C语言版 408 2019-41题代码版

题目&#xff1a; 2019 年 ( 单链表 ) 41 &#xff0e;&#xff08; 13 分&#xff09;设线性表 L ( a 1 , a 2 , a 3 ,…… ,an2, a n 1 , a n ) 采用带头结点的单链表保存&#xff0c;链表中 的结点定义如下&#xff1a; typedef struct node { int data; struc…

Smart PLC模拟量采集和低通滤波器组合应用

SMART PLC模拟量采集功能块"S_ITR"算法公式和详细代码请参考下面文章&#xff1a; 1、模拟量采集功能块"S_ITR" https://rxxw-control.blog.csdn.net/article/details/121347697https://rxxw-control.blog.csdn.net/article/details/1213476972、线性转换…

ARM-v7 程序计数器PC的相关指令与应用

1. 前言 如图1所示&#xff0c;R14是连接寄存器&#xff08;Link Register&#xff09;&#xff0c;在汇编指令中通常也写为LR&#xff0c;用于存储函数调用和异常等的返回信息&#xff0c;复位时&#xff0c;默认值为0xFFFFFFFF&#xff1b; 图1 Core register R15是程序计数…

vscode 配置 c 语言 问题解决

1.VS code调试时显示Unable to start debugging.The value of miDebuggerPath is invalid。 解决方法: VS code调试时显示Unable to start debugging.The value of miDebuggerPath is invalid_unable to start debugging. the value of midebugger-CSDN博客 2.VSCode运行C终端…

提示词工程技术:类比、后退、动态少样本、自动生成CoT

类比提示 “类比提示”利用类比推理的概念&#xff0c;鼓励模型生成自己的例子和知识&#xff0c;从而实现更灵活和高效的解决问题。 后退提示 “后退提示”专注于抽象&#xff0c;引导模型推导出高级概念和原理&#xff0c;进而提高其推理能力。 使用一个基本的数学问题来…

isdigit 是 Python 中字符串对象的一个方法,用于检查字符串中的所有字符是否都是数字。

如果字符串中的所有字符都是数字&#xff0c;则返回 True&#xff0c;否则返回 False。这个方法只能用于检查整数&#xff0c;并且它只能识别 0-9 的数字字符。 这里有一个使用 isdigit 方法的例子&#xff1a; s "12345" if s.isdigit(): print("字符串只包…

npm下载时下载失败解决方法

1.清楚缓存 npm cache clean --force2.切换下载镜像 1.查看当前使用的镜像地址命令 npm config get registry切换为淘宝镜像命令&#xff08;安装一些package容易报错&#xff09; npm config set registry https://registry.npm.taobao.org或官方&#xff1a; npm config…

分类算法(Classification algorithms)

逻辑回归(logical regression&#xff09;&#xff1a; 逻辑回归这个名字听上去好像应该是回归算法的&#xff0c;但其实这个名字只是在历史上取名有点区别&#xff0c;但实际上它是一个完全属于是分类算法的。 我们为什么要学习它呢&#xff1f;在用我们的线性回归时会遇到一…

读书·基于RISC-V和FPGA的嵌入式系统设计·第3章

72.8051单片机的弊端和指令集架构CISC的缺点 76.RV指令集的特征&#xff08;⭐&#xff09; 特权架构和特权指令集是相关但不完全相同的概念。 特权架构&#xff08;Privileged Architecture&#xff09;指的是计算机体系结构中用于实现特权级操作的硬件和软件机制。特权架构定…

RabbitMQ——死信队列

RabbitMQ——死信队列 死信队列&#xff08;Dead Letter Queue&#xff0c;DLQ&#xff09;是 RabbitMQ 中的一种重要特性&#xff0c;用于处理无法被消费的消息&#xff0c;防止消息丢失。 死信的来源 在消息队列中&#xff0c;当消息满足一定条件而无法被正常消费时&#xf…