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

目录

一.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到str5string str6(str3, 3, 5);//从str3的第3个位置取5个字符构造str6string 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;//尾插str2str1 += "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.mzph.cn/news/875092.shtml

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

相关文章

深入浅出WebRTC—Pacer

平滑发包&#xff08;Pacer&#xff09;是 WebRTC 实现高质量实时通信不可或缺的一部分。在视频通信中&#xff0c;单帧视频可能包含大量的数据&#xff0c;如果未经控制地立即发送&#xff0c;可能瞬间对网络造成巨大压力。Pacer 能够根据网络条件动态调整发送速率&#xff0c…

python库(14):Arrow库简化时间处理

1 Arrow简介 Arrow 是一个被称为程序员的时间处理利器的 Python 库。 从诞生起&#xff0c;它就是为了填补 Python 的 datetime 类型的功能空白而生的。为程序员提供了一种更简单、更直观的方式来处理日期和时间。 2 安装Arrow库 pip install arrow -i https://pypi.tuna.ts…

什么是设备运维管理系统?有什么作用?(6款设备运维管理系统推荐)

一、什么是设备运维管理系统&#xff1f; 设备运维管理系统是一种集成了监控、管理、维护和优化设备性能的软件平台。它旨在通过自动化的手段&#xff0c;提高设备运行的可靠性和效率&#xff0c;降低运维成本&#xff0c;并优化资源利用。 设备运维管理系统能够实时监控设备…

【1】Python机器学习之基础概念

1、什么是机器学习 最早的机器学习应用——垃圾邮件分辨 传统的计算机解决问题思路&#xff1a; 编写规则&#xff0c;定义“垃圾邮件”&#xff0c;让计算机执行对于很多问题&#xff0c;规则很难定义规则不断变化 机器学习在图像识别领域的重要应用&#xff1a; 人脸识别…

带您详细了解安全漏洞的产生和防护

什么是漏洞&#xff1f; 漏洞是 IT、网络、云、Web 或移动应用程序系统中的弱点或缺陷&#xff0c;可能使其容易受到成功的外部攻击。攻击者经常试图寻找网络安全中的各种类型的漏洞来组合和利用系统。 一些最常见的漏洞&#xff1a; 1.SQL注入 注入诸如 SQL 查询之类的小代…

BUU [PASECA2019]honey_shop

BUU [PASECA2019]honey_shop 技术栈&#xff1a;任意文件读取、session伪造 开启靶机&#xff0c;我有1336金币&#xff0c;买flag需要1337金币 点击上面的大图&#xff0c;会直接下载图片 抓包看看&#xff0c;感觉是任意文件读取 修改下路径读一下 读到了session密钥是Kv8i…

Springboot validated JSR303校验

1.导入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-validation</artifactId></dependency> 2.测试类 package com.jmj.gulimall.product.testC;import lombok.Data;import javax.val…

C++《类和对象》(中)

一、 类的默认成员函数介绍二、构造函数 构造函数名与类同名内置类型与自定义类型析构函数拷贝构造函数 C《类和对象》(中) 一、 类的默认成员函数介绍 默认成员函数就是⽤⼾没有显式实现&#xff0c;编译器会⾃动⽣成的成员函数称为默认成员函数。 那么我们主要学习的是1&…

Linux环境docker部署Firefox结合内网穿透远程使用浏览器测试

文章目录 前言1. 部署Firefox2. 本地访问Firefox3. Linux安装Cpolar4. 配置Firefox公网地址5. 远程访问Firefox6. 固定Firefox公网地址7. 固定地址访问Firefox 前言 本次实践部署环境为本地Linux环境&#xff0c;使用Docker部署Firefox浏览器后&#xff0c;并结合cpolar内网穿…

手动搭建微型计算机(涉及:CPU、内存、寄存器等)

目录 微型计算机基础元件及作用CPU地址总线数据总线 内存地址总线数据总线内存大小的计算 寄存器先将Z80CPU与TC5517内存相连参考文章 微型计算机基础元件及作用 CPU、内存、I/O CPU 包含地址总线引脚和数据总线引脚。 以Z80CPU为例&#xff1a; 地址总线 地址总线引脚…

Apache Bigtop 正式支持 openEuler,共创大数据新生态

近日&#xff0c;在OpenAtom openEuler&#xff08;简称"openEuler"&#xff09;BigData SIG与Linaro的携手努力下&#xff0c;** Apache Bigtop于2024年7月8日发布的3.3.0新版本中&#xff0c;正式宣告了对openEuler操作系统的原生支持**。这一里程碑式的进展&#…

[微信小程序] css 解决纯数字或字母不自动换行的问题、控制文字行数

效果 css 代码 word-break: break-all; overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;解释 word-break: break-all; 作用&#xff1a;这个属性允许在单词内部进行换行&#xff0c;即使单词很长也…

Mysql - 索引

目录 一、存储引擎 二、索引 索引结构 索引分类 索引语法 联合索引 前缀索引 索引使用规则 最左前缀法则 范围查询使索引失效 字段做运算操作索引失效 字符串字段不加单引号索引失效 字段做前模糊查询索引失效 or连接条件索引失效 数据发布情况索引失效 指定使用…

AIGC高频产品面试题(二)

什么叫大模型&#xff0c;人工智能大模型是什么&#xff1f; 之前&#xff0c;人工智能大多针对特定的场景应用进行训练&#xff0c;生成的模型难以迁移到其他场景&#xff0c;属于“小模型”的范畴。整个训练过程中&#xff0c;不仅手工调参工作量大&#xff0c;还需要给机器“…

[ECCV 2024] [复旦]RECE:扩散模型概念移除,只需3秒即可充分移除风险概念!

本文内容来自公众号粉丝投稿&#xff0c;作者来自复旦大学的视觉与学习实验室(FVL)。研究团队提出了一种可靠、高效的概念移除方法&#xff08;RECE&#xff09;。该方法以解析解的形式&#xff0c;迭代地进行风险概念移除、风险概念嵌入推导&#xff0c;从而确保模型彻底移除风…

【MySQL进阶之路 | 高级篇】优化数据库结构和大表优化

目录结构&#xff1a; 目录 目录结构&#xff1a; 1. 优化数据库结构 1.1 拆分表&#xff1a;冷热数据分离 1.2 增加冗余字段 1.3 优化数据类型 情况1&#xff1a;对整数类型数据进行优化 情况2&#xff1a;既可以使用文本类型也可以使用整数类型的字段&#xff0c;要选…

LeetCode热题100刷题17:124. 二叉树中的最大路径和、437. 路径总和 III、199. 二叉树的右视图

124. 二叉树中的最大路径和 /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(nullptr) {}* TreeNode(int x) : val(x), left(nullptr), right(nul…

Github 2024-07-17 开源项目日报 Top10

根据Github Trendings的统计,今日(2024-07-17统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量非开发语言项目3Python项目3Rust项目2TypeScript项目2MDX项目1项目化学习 创建周期:2538 天协议类型:MIT LicenseStar数量:161973 个Fork数量…

基于51单片机的指纹红外密码电子锁

基于51单片机的指纹红外密码电子锁 1、系统功能介绍2、演示视频3、系统框图4、系统电路介绍4.1、STC89C52单片机最小系统设计4.2、LCD12864显示屏电路设计4.3、矩阵键盘按键控制部分电路设计4.4、AS608指纹模块电路设计 5、程序设计5.1、LCD12864屏幕初始化5.2、AT24C02存储芯片…

打造直播工具详解:从零开始开发直播美颜SDK

今天&#xff0c;笔者将详细讲解如何从零开始开发一个直播美颜SDK&#xff0c;帮助开发者了解开发过程中的关键环节和技术要点。 一、需求分析与规划 在开发之前&#xff0c;首先需要明确美颜SDK的功能需求。一般来说&#xff0c;美颜SDK应包含以下几个核心&#xff1a; 基础…