【C++】string类(二)相关接口介绍及其使用

文章目录

上一篇文章链接:string(一)

(该篇为(一)的续作)

一、string相关接口


1、append

cpp 复制代码
void test04()
{
	string s("hello world");
	s.append("aaa");
	cout << s << endl;
}

2、push_back

对字符串尾插一个字符

cpp 复制代码
void test05()
{
	string s("hello world");
	s.push_back('A');
	cout << s << endl;
}

3、+=

+= 也是用来拼接字符/字符串的,相较以上两种接口,+=更常用。

cpp 复制代码
void test06()
{
	string s("hello world");
	s += 'a';
	s += "bbb";
	cout << s << endl;
}

4、insert

插入

最常用的是第一个,在pos位置插入字符串。

cpp 复制代码
void test07()
{
	string s("hello world");
	s.insert(0, "w");
	cout << s << endl;
}

5、erase

删除元素

cpp 复制代码
void test08()
{
	string s("hello world");
	s.erase(0, 1);//在第0个位置删除1个元素
	cout << s << endl;
}
cpp 复制代码
void test08()
{

	string s("hello world");
	//头删
	s.erase(0, 1);//在第0个位置删除1个元素
	//尾删
	// s.erase(s.size() - 1, 1);
	s.erase(--s.end());//迭代器
	cout << s << endl;
}

6、replace

替换

cpp 复制代码
void test09()
{
	string s("hello world");
	s.replace(0, 2, "a");//从第0个位置开始的2个字符替换为"a"
	cout << s << endl;
}

7、find

查找子字符串str在该字符串中的位置,查找成功返回该子串的首字符位置,失败返回npos

cpp 复制代码
void test11()
{
	string s("hello world");
	cout << s.find(" ");//输出结果为:5
}

练习

练习:

将字符串中的空格全部替换为"%%"

(1)方法1:使用find、replace

cpp 复制代码
void test10()
{
	string s("hello world  aaa bbb ccc  f");
	int pos = s.find(' ');
	while (pos != string::npos)
	{
		s.replace(pos, 1, "%%");
		pos = s.find(' ', pos + 2);

	}
	cout << s << endl;
}

(2)方法2:遍历替换

cpp 复制代码
void test10()
{
	string s("hello world  aaa bbb ccc  f");
	string tmp;
	for (auto ch : s)
	{
		if (ch == ' ')
			tmp += "%%";
		else
			tmp += ch;
	}
	s = tmp;
	cout << s << endl;
}

8、rfind

和find作用相同,只不过是倒着查找。

cpp 复制代码
void test11()
{
	string s("hello world ddd");
	cout << s.rfind(" ");//输出结果为:11
}

9、find_first_of

与字符串str中任一字符进行匹配。

例如:将字符串s中含有a/b/c/d的字符全部修改为*

cpp 复制代码
void test12()
{
	string s("hello world  abfg cdmn");
	int pos = s.find_first_of("abcd");
	while (pos != string::npos)
	{
		s.replace(pos, 1, "*");
		pos = s.find_first_of("abcd", pos + 1);

	}
	cout << s << endl;
}

10、find_last_of

与字符串str中任一字符进行匹配,但是倒着进行查找匹配。

11、find_first_not_of

排除,查找字符串中非str中任一字符的下标。

例如:将字符串s中非a/b/c/d的字符全部修改为*

cpp 复制代码
void test12()
{
	string s("hello world  abfg cdmn");
	int pos = s.find_first_not_of("abcd");
	while (pos != string::npos)
	{
		s.replace(pos, 1, "*");
		pos = s.find_first_not_of("abcd", pos + 1);

	}
	cout << s << endl;
}

12、find_last_not_of

查找字符串中非str中任一字符的下标,但是倒着进行查找匹配。

13、substr

拷贝该字符串中第pos位置,长度为len的子串。

cpp 复制代码
void test13()
{
	string s("hello world");
	
	cout << s.substr(6) << endl;
}

二、谢谢观看!

相关推荐
我还记得那天2 分钟前
C语言递归实现汉诺塔问题
c语言·开发语言
90后的晨仔3 分钟前
Android 程序入口与核心组件详解
android
不吃土豆的马铃薯4 分钟前
Spdlog 入门:日志记录器与日志槽基础详解
服务器·开发语言·c++·c·日志·spdlog
此生决int7 分钟前
算法从入门到精通——前缀和
c++·算法·蓝桥杯
90后的晨仔10 分钟前
Kotlin 简介与开发环境搭建
android
凯瑟琳.奥古斯特12 分钟前
传输层核心功能解析
开发语言·网络·职场和发展
Fuyo_111927 分钟前
C++中的活字印刷术——模板·初阶
开发语言·c++·笔记
小白|28 分钟前
cmake:昇腾CANN构建系统完全指南
java·c++·算法
在角落发呆29 分钟前
跨越网络鸿沟:传统文件传输与现代内网穿透的奇妙交响
开发语言·php
王老师青少年编程29 分钟前
2026年全国青少年信息素养大赛“算法应用主题赛”(初赛)【C++考点大纲】(全场景、组别):文末附备考秘籍!
c++·全国青少年信息素养大赛·初赛·2026年·算法应用主题赛·考点大纲