C++STL详解(一)——String接口详解(上)!!!

news2024/12/24 8:56:06

目录

一.string类介绍

二.string类的构造+赋值

2.1string类的拷贝和构造函数

2.2深拷贝

三.string类的插入

3.1push_back

3.2append

3.3+=操作符

3.4insert

四.string的删除

4.1pop_back

4.2erase

五.string的查找

5.1find

5.2rfind

六.string的比较

6.1compare函数

6.2关系操作符重载

七.string的替换

八.string的交换

九.后记

一.string类介绍

string类是CPP中STL中处理字符串的一个类,它给我们提供了丰富的接口以供于我们使用。

虽然我们传统的C库中有相关的函数以供于我们使用,但是由于操作起来比较麻烦,因此CPP中实现了string类。

string类所在的头文件为<string>

#include <string>

二.string类的构造+赋值

2.1string类的拷贝和构造函数

我们将构造具体的使用方法写在注释里。

在string类中,我们常用的构造和赋值如下:

	string();//构造空字符串
	string(const char* s);//复制指向s的字符序列
	string(size_t n, char c);//生成长度为n,全是c字符的字符串
	string(const char* s, size_t n);//复制s所指向的字符序列的前n个字符
	string(const string & str);//生成str的字符序列一样的字符串
	string(const string & str, size_t pos, size_t len = npos);//从str的pos位置复制len长的字符序列构造字符串
	string& operator= (const string & str);
	string& operator= (const char* s);

我们大家注意到,有一个无符号的整型len=npos,这里的npos其实是-1。它代表的是整型的最大值。

这里大家如果不理解的话可以如此理解:

11111111为有符号的-1的补码,但是在无符号整型中,我们不将它认作补码,而是8位全1的一个数,因此我们会将-1判定为2^8-1,也就是8位的最大值。

下面我们通过实例化带大家体验这几个函数:

	string str1;//空字符串-->只有一个‘\0’的字符串
	string str2("woshikuku");//构造woshikuku\0的字符串
	string str3(36, 'd');//构造由36个字符D组成的字符串
	string str4("woshikuku", 3);//复制woshikuku的前三个字符
	string str5(str3);//复制str3到str5
	string str6(str3, 3, 5);//从str3的第3个位置取5个字符构造str6
	string str7 = "woshikuku";
	string str8 = str7;

 2.2深拷贝

我们在完成string的拷贝时,实现的是深拷贝,而不是浅拷贝。

下面我们介绍一下浅拷贝和深拷贝

浅拷贝:也称位拷贝,编译器只是将对象中的值拷贝过来。如果对象中管理资源,最后就会导致多个对象共享同一份资源,当一个对象销毁时就会将该资源释放掉,而此时另一些对象不知道该资源已经被释放,以为还有效,所以当继续对资源进项操作时,就会发生发生了访问违规。

可以采用深拷贝解决浅拷贝问题,

深拷贝:每个对象都有一份独立的资源,不要和其他对象共享。

如果一个类中涉及到资源的管理,其拷贝构造函数、赋值运算符重载以及析构函数必须要显式给出。一般情况都是按照深拷贝方式提供。

三.string类的插入

3.1push_back

push_back是尾插一个字符的函数,函数原型如下:

void push_back (char c)

需要我们大家注意的是,这个函数只能尾插一个字符。

这个函数的使用如下:

需要大家注意的是,库中并没有提供头插函数。 

3.2append

相比于push_back,append函数用于尾插一个字符串或者一个c风格的字符序列。

append的重载很多,我们大家可以根据注释学习

string& append(const string & str);//尾插str
string& append(const string & str, size_t subpos, size_t sublen);//尾插str的[subpos,subpos+sublen]区间的字符串
string & append(const char* s);//尾插s指向的字符序列
string& append(const char* s, size_t n);//尾插s指向的字符序列的前n个
string& append(size_t n, char c);//尾插n个c
string& append(InputIterator first, InputIterator last);//迭代器版本,暂时不学

下面我们通过实际运用来帮助大家理解这系列的函数: 

 3.3+=操作符

同样的,我们也可以通过+=操作符来完成尾插操作。

该操作符重载了三个版本,我们直接使用即可。

	str1 += 'c';//尾插一个‘c’
	str1 += str2;//尾插str2
	str1 += "asdgdfg";//尾插该字符序列

+=操作符完成的是尾插操作,这三个版本中,尾插一个字符的函数是通过push_back实现的。而尾插字符串是通过append实现的。

3.4insert

在cpp库中,实现了如下的insert函数:

大家可以通过注释来学习函数的作用

需要大家掌握几个常用的函数,譬如下图中的第1、3、4个。

string& insert(size_t pos, const string& str);//在pos位置插入str
string& insert(size_t pos, const string& str, size_t subpos, size_t sublen);//在str的subpos位置读取sublen长度并插入_str的pos位置
string & insert(size_t pos, const char* s);//在pos位置插入一个字符序列s
string& insert(size_t pos, const char* s, size_t n);//在pos位置插入s字符序列的前n个字符
string& insert(size_t pos, size_t n, char c);//在pos位置插入n个c字符
void insert(iterator p, size_t n, char c);//在迭代器p位置插入n个c字符
iterator insert(iterator p, char c);//在迭代器p位置插入一个c字符
void insert(iterator p, InputIterator first, InputIterator last);//在迭代器p位置插入迭代器first到end区间内的字符。(前闭后开)

 现在我们通过使用这些函数来熟悉这些函数的用法:

四.string的删除

string库中提供的删除函数一共有两个。

分别是尾删pop_back和erase。

4.1pop_back

void pop_back();

 这个函数和尾插类似,是删除最后一个字符的函数。

4.2erase

erase函数和insert函数的功能是相反的,一个是插入,而另一个是删除。

C库中实现了如下的erase版本

string& erase (size_t pos = 0, size_t len = npos);//从pos位置删除len长的字符
iterator erase (iterator p);//删除迭代器p指向位置的字符
iterator erase (iterator first, iterator last);//删除迭代器区间[first,last)位置处的字符

实践代码如下: 

string str1("woshikuku");
str1.erase(0, 1);
cout << str1 << endl;
str1.erase(str1.begin());
cout << str1 << endl;
str1.erase(str1.begin() + 1, str1.end() - 1);
cout << str1 << endl;

打印结果如下: 

五.string的查找

5.1find

在这部分内容中,我们将学习两个函数,分别是find和rfind。 

size_t find(const string& str, size_t pos = 0) const;//从pos位置开始搜索str
size_t find(const char* s, size_t pos = 0) const;//从pos位置开始搜索字符序列s
size_t find(const char* s, size_t pos, size_t n) const;//查找字符序列s从pos位置处前n个字符出现的位置
size_t find(char c, size_t pos = 0) const;//从pos位置开始搜索字符c

这部分代码我们直接进行实践: 

5.2rfind

如果说find函数是从前到后查找的,那么rfind函数就是从后往前查找的。 

这里不再过多赘述,只将函数原型放出:

size_t rfind (const string& str, size_t pos = npos) const;	
size_t rfind (const char* s, size_t pos = npos) const;
size_t rfind (const char* s, size_t pos, size_t n) const;
size_t rfind (char c, size_t pos = npos) const;

六.string的比较

string的比较方法有两种,分别是库中的compare函数以及重载操作符。我们逐个进行讲解。

6.1compare函数

 函数原型如下:

int compare(const string& str) const;//调用的对象与字符串str进行比较
int compare(size_t pos, size_t len, const string& str) const;//调用的对象比较[pos,pos+len)区间内的内容
int compare(size_t pos, size_t len, const string& str,size_t subpos, size_t sublen) const;//调用的对象比较[pos,pos+len)区间内的内容,被比较的对象比较[subpos,sublen)区间的内容
int compare(const char* s) const;
int compare(size_t pos, size_t len, const char* s) const;
int compare(size_t pos, size_t len, const char* s, size_t n) const;//跟s字符序列的前n个进行比较

6.2关系操作符重载

库中对如下的关系操作符进行了重载:==、!=、<、<=、>、>=。

重载后的关系运算符支持string类和string类之间的关系比较、string类和字符串之间的关系比较、字符串和string类之间的关系比较。

因此我们可以通过上述的关系操作符来进行字符串的比较

如下例所示:

七.string的替换

string的替换操作是通过replace来完成的。

我们可以随意的进行替换,譬如我们可以将源字符串的一个字符替换成另外两个字符。

这里我们学习两个函数:

string& replace(size_t pos, size_t len, const char* s);//从pos位置开始的len长度被s字符串替换
string& replace(size_t pos, size_t len, size_t n, char c);//从pos位置开始的len长度被n个c替代。

 

这个函数在使用中需要大家注意的是,我们替换的是某个区间的字符序列,我们可以把一个字符替换成三个字符,也可以把三个字符替换成一个字符。 

八.string的交换

 由于算法库中的swap函数需要通过构造一个新的字符串来完成交换。而我们构造字符串需要多次深拷贝,因此它的效率是极其低的。

所以我们通过交换指针的形式写了swap函数。

void swap (string& x, string& y);
void swap (string& str);

我们可以通过对象调用成员函数的swap,也可以直接调用非成员函数的swap。

使用方法如下:

	//成员函数
	s1.swap(s2);
	//非成员函数
	swap(s1, s2);

swap函数完成了两个对象的交换。 这里不再给出example。

九.后记

 string类的接口上是这篇博文:string接string接口下

有关string类的模拟实现可参考此片博文:string的模拟实现

如果你想更深入的了解string类函数的使用方法,可参考cpp官网:cpp官网

码字不易,给个点赞收藏叭~~~

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

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

相关文章

LeetCode 热题 HOT 100 (011/100)【宇宙最简单版】

【图论】No. 0200 岛屿数量 【中等】&#x1f449;力扣对应题目指路 希望对你有帮助呀&#xff01;&#xff01;&#x1f49c;&#x1f49c; 如有更好理解的思路&#xff0c;欢迎大家留言补充 ~ 一起加油叭 &#x1f4a6; 欢迎关注、订阅专栏 【力扣详解】谢谢你的支持&#xf…

使用AOP优化Spring Boot Controller参数:自动填充常用字段的技巧

欢迎来到我的博客&#xff0c;代码的世界里&#xff0c;每一行都是一个故事 &#x1f38f;&#xff1a;你只管努力&#xff0c;剩下的交给时间 &#x1f3e0; &#xff1a;小破站 使用AOP优化Spring Boot Controller参数&#xff1a;自动填充常用字段的技巧 前言为什么使用AOP为…

web网站组成

web网站由四部分组成&#xff1a;浏览器 前端服务器 后端服务器 数据库服务器 流程&#xff1a; 1.浏览器输入网站后&#xff0c;向前端服务器发送请求&#xff0c;前端服务器响应&#xff0c;静态的数据给浏览器。 2.前端代码中script中有url,这个是向后台发送请求的网…

项目标红,识别不了maven项目,解决办法

首先&#xff0c;检查 preferences 其次&#xff0c;检查IDEA 的 jdk。File-》Project Structure 最后&#xff1a; 1. 2. mvn clean install -Dmaven.test.skiptrue 跳过单元测试 maven跳过单元测试-maven.test.skip和skipTests的区别-CSDN博客

vue3+g2plot实现词云图

词云图 效果预览: 核心代码: import {WordCloud } from @antv/g2plot;fetch(https://gw.alipayobjects.com/os/antfincdn/jPKbal7r9r/mock.json).then((res) => res.json()).then((data) => {const wordCloud = new WordCloud(container, {data,wordField: x,weigh…

细说MCU用DMA实现DAC输出的方法

目录 一、建立新工程 1.项目依赖的硬件 2.配置DAC 3.配置DMA 4.配置TIM3 5.选择时钟源和Debug 6.配置系统时钟 二、代码修改 1. 启动定时器和DMA 2.定义输出波形数据 3.通过MATLAB产生这个波形数据的方法 三、查看结果 用DMA的方式将位于存储器(数组)中的数据传递…

centos中zabbix安装、卸载及遇到的问题

目录 Zabbix简介Zabbix5.0和Zabbix7.0的区别监控能力方面模板和 API 方面性能、速度方面 centos7安装Zabbix(5.0)安装zabbix遇到的问题卸载Zabbix Zabbix简介 Zabbix 是一个基于 WEB 界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案。zabbix 能监视各种网络参…

三分钟带你了解Python文件操作与IO流

在探索编程世界的奇幻旅程中&#xff0c;文件操作和IO&#xff08;输入/输出&#xff09;流是每一个探险者必须掌握的基础技能。在Python的世界中&#xff0c;这些技能尤为关键&#xff0c;它们像是巫师手中的魔杖&#xff0c;能让我们与文件进行深度的交流。本文将带你快速了解…

springboo 整合 redis

springBoot 整合 redis starter启动依赖。—包含自动装配类—完成相应的装配功能。 引入依赖 <!--引入了redis整合springboot 的依赖--> <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis&…

泵浦光与斯托克斯光相遇耦合效应的matlab模拟与仿真

目录 1.程序功能描述 2.测试软件版本以及运行结果展示 3.核心程序 4.本算法原理 4.1拉曼散射基础 4.2非线性耦合方程 5.完整程序 1.程序功能描述 泵浦光与斯托克斯光相遇耦合效应的matlab模拟与仿真. 2.测试软件版本以及运行结果展示 MATLAB2022A版本运行 &#xff0…

面试场景题系列--(2)短 URL 生成器设计:百亿短 URL 怎样做到无冲突?--xunznux

文章目录 面试场景题&#xff1a;短 URL 生成器设计&#xff1a;百亿短 URL 怎样做到无冲突&#xff1f;1. 需求分析2. 短链接生成算法2.1 自增法2.2 散列函数法2.3 预生成法 3. 部署模型3.1 其他部署方案 4. 设计4.1 重定向响应码4.2 短 URL 预生成文件及预加载4.3 用户自定义…

redis 基础命令

1.数据库命令 select 库名&#xff1b;切换库 flushdb 清空库 flushall 清空所有库 redis支持的数据类型有很多&#xff0c;使用最频繁的有String 字符串类型&#xff0c;List队列&#xff0c;Hash&#xff0c;Zset有序集合&#xff0c;Set集合。 2.字符串类型命令 表示k…

[IMX6ULL]移植NXP Linux Kernel 5.15

移植NXP Linux Kernel 5.15 2024-7-7 hongxi.zhu 1. 下载NXP Linux Kernel 5.15 仓库[nxp-imx/linux-imx] git clone -b lf-5.15.y https://github.com/nxp-imx/linux-imx.git 2. 编译NXP Linux Kernel 5.15 make ARCHarm CROSS_COMPILEarm-linux-gnueabihf- distclean make…

细说MCU用DMA改变DAC输出信号频率和改善输出波形质量的方法

目录 一、参考硬件 二、修改定时器参数改变输出波形频率 三、改善波形质量 四、代码修改 五、查看结果 一、参考硬件 本项目的软件硬件工程参考作者的其他文章&#xff1a;细说MCU用DMA实现DAC输出的方法-CSDN博客 https://wenchm.blog.csdn.net/article/details/14065…

2024暑假友谊赛 2

Problem - 1150B - Codeforces 小C是重度强迫症晚期患者&#xff0c;如果某些图形无法按照他的想法排列&#xff0c;那么他就会迎来他的末日。某天小C来到了心心念念的女神家里&#xff08;绝对不可能是女装大佬&#xff0c;绝对不可能&#xff09;&#xff0c;他发现地砖有两…

醒醒,别睡了...讲《数据分析pandas库》了—/—<2>

废话不多说&#xff0c;直接开讲! 一、 1、pandas变量类型的转换 Pandas 支持的数据类型 &#xff1a; 1、float&#xff1a;浮点型 2、int&#xff1a;整型 3、string&#xff1a;字符串类型 4、bool&#xff1a;布尔类型 5、datetime64[nsr]&#xff1a; 示精确到纳秒的日期…

跨棒距、公法线和齿厚对应关系分析

前面有一期讨论了下滚齿径向进刀量和齿厚的对应关系&#xff1a;《》&#xff0c;有小伙伴又问了&#xff0c;加工时是用跨棒距或者公法线去控制齿厚的&#xff0c;直接给齿厚是无法测量的&#xff0c;如果测一个值再去计算&#xff0c;有点麻烦&#xff0c;有没有他们之间的对…

【操作系统】解析线程安全中的 Synchronized 关键字

目录 synchronized一、互斥性二、可重入性三、synchronized的使用 synchronized synchronized作为确保多线程安全的重要关键字 接下来我们来学习它的特性&#xff1a; 互斥性可重入性 一、互斥性 synchronized会起到互斥效果,某个线程执行到某个对象的synchronized中时,其他…

【详谈】HashMAP深度剖析,全面消化吸收

【万字长文】 还没写完!!还没写完!!!还在码字中,只是先放上,防止又写着没了,自己文件没了… 最近,可以说的上自己博客停更大约有一两个月了,一直在忙于公司中的项目和业务,典型的牛马看了都流泪 今天,自己刚刚优化了一个查询耗时的BUG,在这里我就引入的hashmap作为我存储队列的…

Linux 某进程 CPU 高问题,用 Shell 脚本发现处理

发现高CPU使用率进程 首先&#xff0c;我们需要编写一个Shell脚本来发现系统中CPU使用率最高的进程。以下是一个简单的脚本示例&#xff1a; #!/bin/bash# 设置 CPU 使用率的阈值,一般设置90&#xff1b;这里是demo&#xff0c;所以用30 CPU_THRESHOLD30# 获取占用 CPU 最高的…