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

news2024/10/2 14:25:11

📙 作者简介 :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后面加入s1
	string 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)); //取后缀并拷贝构造suffix
	cout << 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_t

int 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.coloradmin.cn/o/1505279.html

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

相关文章

双链表()

双链表 实现一个双链表&#xff0c;双链表初始为空&#xff0c;支持 55 种操作&#xff1a; 在最左侧插入一个数&#xff1b;在最右侧插入一个数&#xff1b;将第 k 个插入的数删除&#xff1b;在第 k 个插入的数左侧插入一个数&#xff1b;在第 k 个插入的数右侧插入一个数 …

【LeetCode: 299. 猜数字游戏 - 模拟 + 计数】

&#x1f680; 算法题 &#x1f680; &#x1f332; 算法刷题专栏 | 面试必备算法 | 面试高频算法 &#x1f340; &#x1f332; 越难的东西,越要努力坚持&#xff0c;因为它具有很高的价值&#xff0c;算法就是这样✨ &#x1f332; 作者简介&#xff1a;硕风和炜&#xff0c;…

解决阿里云服务器开启frp服务端,内网服务器开启frp客户端却连接不上的问题

解决方法&#xff1a; 把阿里云自带的Alibabxxxxxxxlinux系统 换成centos 7系统&#xff01;&#xff01;&#xff01;&#xff01; 说一下我的过程和问题&#xff1a;由于我们内网的服务器在校外是不能连接的&#xff0c;因此我弄了个阿里云服务器做内网穿透&#xff0c;所谓…

nRF52832——GPIO端口的应用

nRF52832——GPIO端口的应用 nRF52832 GPIO 端口资源描述nRF52832 GPIO 寄存器介绍GPIO 端口状态的设置GPIO 输出设置 nRF52832 GPIO 输出应用点亮第一个 LED 灯硬件部分Keil 工程搭建 蜂鸣器驱动硬件设计程序编写测试验证 nRF52832 GPIO 输入应用GPIO 输入扫描流程机械按键输入…

基于GAN对抗网进行图像修复

一、简介 使用PyTorch实现的生成对抗网络&#xff08;GAN&#xff09;模型&#xff0c;包括编码器&#xff08;Encoder&#xff09;、解码器&#xff08;Decoder&#xff09;、生成器&#xff08;ResnetGenerator&#xff09;和判别器&#xff08;Discriminator&#xff09;。…

vue 自定义组件绑定model+弹出选择支持上下按键选择

参考地址v-modelhttps://v2.cn.vuejs.org/v2/guide/components-custom-events.html#%E8%87%AA%E5%AE%9A%E4%B9%89%E7%BB%84%E4%BB%B6%E7%9A%84-v-model 原文代码 Vue.component(base-checkbox, {model: {prop: checked,event: change},props: {checked: Boolean},template: `…

阅读最新的论文,研究趋势

我们需要时刻了解技术的发展趋势&#xff0c;阅读最新的论文研究。那么&#xff0c;怎么阅读论文最高效&#xff1f;最近我们使用了全新的阅读方法&#xff1a; 第一步&#xff0c;阅读最新分类好的列表 第二步&#xff0c;挑选感兴趣的论文&#xff0c;阅读其一页纸总结 第三步…

spring-cloud-openfeign 3.0.0之前版本(对应spring boot 2.4.x之前版本)feign配置加载顺序

在之前写的文章配置基础上 https://blog.csdn.net/zlpzlpzyd/article/details/136060312 下图为自己整理的

rk3399使用阿里推理引擎MNN使用cpu和gpu进行benchmark,OpenCL效果不佳?

视频讲解 rk3399使用阿里推理引擎MNN使用cpu和gpu进行benchmark&#xff0c;OpenCL效果不佳&#xff1f; 背景 MNN是阿里开源的推理引擎&#xff0c;今天测试一下在rk3399平台上的benchmark怎么样&#xff1f; alibaba/MNN: MNN is a blazing fast, lightweight deep learning…

百家争鸣!AI艺术生成器的进化: 深入AI生成艺术世界

人工智能&#xff08;AI&#xff09;已经彻底改变了艺术界&#xff0c;AI艺术生成器现在能够创作出独特而迷人的作品。然而&#xff0c;关于AI生成艺术与人类创作艺术的艺术价值的争论仍然在引起争议。 社区对AI生成图像的原创性和所有权提出了关注&#xff0c;导致了法律纠纷和…

第十六章垃圾回收相关概念

第十六章垃圾回收相关概念 文章目录 第十六章垃圾回收相关概念1. System.gc()的理解2. 内存溢出与内存泄漏2.1 内存溢出&#xff08;OOM&#xff09;2.2 内存泄漏&#xff08;Memory Leak&#xff09; 3. Stop The World4. 垃圾回收的并行与并发4.1 并发&#xff08;Concurrent…

基于SpringBoot的招聘网站

基于jspmysqlSpring的SpringBoot招聘网站项目&#xff08;完整源码sql&#xff09; 博主介绍&#xff1a;多年java开发经验&#xff0c;专注Java开发、定制、远程、文档编写指导等,csdn特邀作者、专注于Java技术领域 作者主页 央顺技术团队 Java毕设项目精品实战案例《1000套》…

ModuleNotFoundError: No module named ‘aitodpycocotools‘

具体不清楚&#xff0c;反正pip下载也下载不了&#xff0c;改为pycocotools后没问题了 解决 分析 是承接之前错误&#xff0c;为了解决keyerror问题&#xff0c;pip install -v -e .重新安装mmdet&#xff0c;导致的

PostgreSQL 安装部署

文章目录 一、PostgreSQL部署方式1.Yum方式部署2.RPM方式部署3.源码方式部署4.二进制方式部署5.Docker方式部署 二、PostgreSQL部署1.Yum方式部署1.1.部署数据库1.2.连接数据库 2.RPM方式部署2.1.部署数据库2.2.连接数据库 3.源码方式部署3.1.准备工作3.2.编译安装3.3.配置数据…

[LeetCode][LCR151]彩灯装饰记录 III——队列

题目 LCR 151. 彩灯装饰记录 III 一棵圣诞树记作根节点为 root 的二叉树&#xff0c;节点值为该位置装饰彩灯的颜色编号。请按照如下规则记录彩灯装饰结果&#xff1a; 第一层按照从左到右的顺序记录除第一层外每一层的记录顺序均与上一层相反。即第一层为从左到右&#xff0c…

Spring AOP底层原理

目录 代理模式 静态代理 动态代理 1. JDK动态代理 创建⼀个代理对象并使用 2. CGLIB动态代理 SpringAOP底层原理面试 代理模式 Spring AOP是基于动态代理模式来实现的 代理模式&#xff1a;静态代理模式动态代理模式 代理模式, 也叫委托模式。 定义&#xff1a;为其…

Mysql - is marked as crashed and should be repaired

概述 上周发生了一个Mysql报错的问题&#xff0c;今天有时间整理一下产生的原因和来龙去脉&#xff0c;Mysql的版本是5.5,发生错误的表存储引擎都是MyISAM,产生的报错信息是Table xxxxxx is marked as crashed and should be repaired。 定位问题 产生的后果是Nginx服务没有…

Util工具类功能设计与类设计(http模块一)

目录 类功能 类定义 类实现 编译测试 Split分割字符串测试 ReadFile读取测试 WriteFile写入测试 UrlEncode编码测试 UrlDecode编码测试 StatuDesc状态码信息获取测试 ExtMime后缀名获取文件mime测试 IsDirectory&IsRegular测试 VaildPath请求路径有效性判断测…

基于Springboot的招生宣传管理系统(有报告)。Javaee项目,springboot项目。

演示视频&#xff1a; 基于Springboot的招生宣传管理系统&#xff08;有报告&#xff09;。Javaee项目&#xff0c;springboot项目。 项目介绍&#xff1a; 采用M&#xff08;model&#xff09;V&#xff08;view&#xff09;C&#xff08;controller&#xff09;三层体系结构…

基于springboot的医院信息管理系统(程序+代码+文档)

** &#x1f345;点赞收藏关注 → 私信领取本源代码、数据库&#x1f345; 本人在Java毕业设计领域有多年的经验&#xff0c;陆续会更新更多优质的Java实战项目&#xff0c;希望你能有所收获&#xff0c;少走一些弯路。&#x1f345;关注我不迷路&#x1f345;** 一、研究背景…