【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;
}

二、谢谢观看!

相关推荐
小年糕是糕手几秒前
【C语言】函数栈帧的创建和销毁
java·c语言·开发语言·数据结构·c++·链表
ALex_zry12 分钟前
构建通用并发下载工具:用Golang重构wget脚本的实践分享
开发语言·重构·golang
努力努力再努力wz16 分钟前
【Linux进阶系列】:信号(下)
java·linux·运维·服务器·开发语言·数据结构·c++
21号 124 分钟前
21.事务和锁(重点)
开发语言·数据库
zzzsde32 分钟前
【C++】stack和queue:使用&&OJ题&&模拟实现
开发语言·c++
m0_7482336444 分钟前
C++与Python:内存管理与指针的对比
java·c++·python
孤廖1 小时前
面试官问 Linux 编译调试?gcc 编译流程 + gdb 断点调试 + git 版本控制,连 Makefile 都标好了
linux·服务器·c++·人工智能·git·算法·github
终焉代码1 小时前
【Linux】进程初阶(1)——基本进程理解
linux·运维·服务器·c++·学习·1024程序员节
我想吃余1 小时前
Linux进程间通信:管道与System V IPC的全解析
linux·服务器·c++
紫荆鱼1 小时前
设计模式-备忘录模式(Memento)
c++·后端·设计模式·备忘录模式