string
目录
六、STL简介
(一)什么是STL
(二)STL的版本
(三)STL六大组件
七、string
(一)标准库中的string
1、string类
2、string常用的接口
1)string类对象的常见构造
2)string类对象的容量操作
3)string类对象的访问及遍历操作
4)string类对象的修改操作
5)string类非成员函数
(二)string模拟实现
1、浅拷贝
2、深拷贝
3、实现
六、STL简介
(一)什么是STL
STL(standard template libaray- 标准模板库 ) : 是 C++ 标准库的重要组成部分 ,不仅是一个可复用的组件库,而且 是一个包罗数据结构与算法的软件框架 。(二)STL的版本
原始版本Alexander Stepanov 、 Meng Lee 在惠普实验室完成的原始版本,本着开源精神,他们声明允许任何人任意运用、拷贝、修改、传播、商业使用这些代码,无需付费。唯一的条件就是也需要向原始版本一样做开源使用。 HP 版本 -- 所有 STL 实现版本的始祖。P. J. 版本由 P. J. Plauger 开发,继承自 HP 版本,被 Windows Visual C++ 采用,不能公开或修改,缺陷:可读性比较低,符号命名比较怪异。RW 版本由 Rouge Wage 公司开发,继承自 HP 版本,被 C+ + Builder 采用,不能公开或修改,可读性一般。SGI 版本由 Silicon Graphics Computer Systems , Inc 公司开发,继承自 HP 版 本。被 GCC(Linux) 采用,可移植性好,可公开、修改甚至贩卖,从命名风格和编程 风格上看,阅读性非常高。我们后面学习 STL 要阅读部分源代码, 主要参考的就是这个版本。(三)STL六大组件
学习STL的三个境界:能用,明理,能扩展 。
七、string
string严格来说不是STL,而是标准库。
(一)标准库中的string
1、string类
2、string常用的接口
1)string类对象的常见构造

以下是常用的构造方式
string s1;string s2("123");string s3 = "123";string s4(s3);
2)string类对象的容量操作
| 函数名称 | 作用 |
|---|---|
| size | 返回字符串有效长度 |
| length | 返回字符串有效长度 |
| capacity | 返回空间总大小 |
| empty | 若字符串为空返回true,不为空返回false |
| clear | 清空有效字符 |
| reserve | 预留空间 |
| resize | 将字符串大小改为n |
#include<string>
int main()
{string s = "C++";cout << s << endl;cout <<"s.size():"<< s.size() << endl;cout <<"s.length():"<< s.length() << endl;cout << "s.capacity():"<<s.capacity() << endl;cout << "s.empty():"<<s.empty() << endl;cout << "-----------------------------------------------------" << endl;s.resize(6);cout << "s.size():" << s.size() << endl;cout << "s.capacity():" << s.capacity() << endl;cout << "-----------------------------------------------------" << endl;s.reserve(16);cout << "s.capacity():" << s.capacity() << endl;cout << "-----------------------------------------------------" << endl;s.clear();cout << "s.empty():" << s.empty() << endl;return 0;
}

3)string类对象的访问及遍历操作
| 函数名称 | 作用 |
| operator[] | 返回 pos 位置的字符, const string 类对象调用 |
| begin+end | 返回首元素地址+返回最后一个元素的下一个位置的地址 |
| rbegin+rend | 返回最后一个元素的地址+返回第一个元素的前一个位置地址 |
| 范围for | for的新遍历方式(C++11) |
string s = "asdfghjkl";string::iterator it = s.begin();while (it != s.end()){cout << *it ;it++;}cout << endl;
这就是正向迭代器,其中string::iterator也可以用auto
string s = "asdfghjkl";auto it = s.begin();while (it != s.end()){cout << *it ;it++;}cout << endl;
![]()
还有反向迭代器
string s = "asdfghjkl";auto it = s.rbegin();while (it != s.rend()){cout << *it ;it++;}cout << endl;
范围for(原理:编译器会将范围for变成迭代器)
string s = "asdfghjkl";for (auto a : s){cout << a;}cout << endl;
4)string类对象的修改操作
| 函数名称 | 作用 |
| push_back | 在字符串尾部添加字符 |
| append | 在字符串后面追加一个字符串 |
| operator+= | 在字符串后面追加字符串str |
| c_str | 返回C格式的字符串 |
| find+npos | 从字符串pos位置开始往后找字符,返回该字符在字符串中的位置 |
| rfind | 从字符串pos位置开始往前找字符,返回该字符在字符串中的位置 |
| substr | 在str中从pos位置开始,截取n个字符,然后将其返回 |
| insert | 插入字符或字符串 |
| erase | 删除字符或字符串 |
int main()
{string s = "hello ";cout << s << endl;cout << "------------------------------------------------" << endl;s.push_back('w');cout << s << endl;cout << "------------------------------------------------" << endl;s += "orld";cout << s << endl;cout << "------------------------------------------------" << endl;s.append(" /C++");cout << s << endl;cout << "------------------------------------------------" << endl;cout << s.find('h') << endl;cout << "------------------------------------------------" << endl;cout << s.substr(2, 5) << endl;cout << "------------------------------------------------" << endl;s.insert(0,1,'+');s.insert(s.begin(), '+');cout << s << endl;cout << "------------------------------------------------" << endl;s.erase(0, 2);cout << s << endl;cout << "------------------------------------------------" << endl;return 0;
}

注意,我们在文档时,substr是有缺省值的
当我们不给截多少字符的时候,会给npos值,那么npos值是多少呢???

是-1吗???
文档中npos的类型是size_t,这是无符号整形,也就是说这里的-1并不真的是,而是42亿+
到现在为止,我们并没有遇到过这么大的长度,所以可以理解为,截到字符串结束
还有值得注意的是insert

在插入一个字符的时候我们需要传三个参数,或者传迭代器也就是(6)
s.insert(0,1,'+'); //(5)s.insert(s.begin(), '+'); //(6)

当erasr没有第二个参数时,默认为删除到字符串最后
5)string类非成员函数
| 函数名称 | 作用 |
| operator+ | 字符串添加,不改变原来的字符串 |
| operator>> | 输入运算符重载 |
| operator<< | 输出运算符重载 |
| getline | 获取一行字符串 |
| relational operators | 比较大小 |
#include<string>
int main()
{string s = "hello ";cout << s << endl;cout << "------------------------------------------------" << endl;string s2 = s + "C++";cout << s << endl;cout << s2 << endl;cout << "------------------------------------------------" << endl;string s4;getline(cin, s4);cout << s4 << endl;cout << "------------------------------------------------" << endl;return 0;
}

getline主要是解决cin遇到空格就停止读取的问题
这些是比较常见的string接口,当然还有很多接口

具体介绍,大家可以看看官网
https://cplusplus.com/
(二)string模拟实现
1、浅拷贝
下面代码是有问题的
class String
{
public:
/*String():_str(new char[1]){*_str = '\0';}*///String(const char* str = "\0") 错误示范//String(const char* str = nullptr) 错误示范String(const char* str = ""){// 构造String类对象时,如果传递nullptr指针,可以认为程序非if (nullptr == str){assert(false);return;}_str = new char[strlen(str) + 1];strcpy(_str, str);}~String(){if (_str){delete[] _str;_str = nullptr;}}
private:char* _str;
};
// 测试
void TestString()
{String s1("hello bit!!!");String s2(s1);
}

2、深拷贝
3、实现
代码仅供参考
class string
{friend ostream& operator<<(ostream& out, const string& s);friend istream& operator>>(istream& in, string& s);
public:typedef char* iterator;string(const char* str = ""):_size(strlen(str)),_capacity(_size){_str = new char[_capacity + 1];strcpy(_str, str);}string(const string& s){char* tmp = new char[_capacity + 1];strcpy(tmp, s._str);_str = tmp;_size = s._size;_capacity = s._capacity;}~string(){delete[] _str;_str = nullptr;_size = _capacity = 0;}iterator begin(){return _str;}iterator end(){return _str + _size;}const iterator begin()const{return _str;}const iterator end()const{return _str + _size;}void reserve(size_t n){if(n>_capacity){char* tmp = new char[n+1];strcpy(tmp,_str);delete[] _str;_str = tmp;_capacity = n;}}void push_back(char c){if (_size == _capacity){reserve(_capacity == 0 ? 4 : _capacity * 2);}_str[_size] = c;_size++;_str[_size] = '\0';}string& operator+=(char c){push_back(c);return *this;}void append(const char* str){size_t len = strlen(str);if (_size + len > _capacity){reserve( _size + len );}strcpy(_str + _size, str);_size += len;}string& operator+=(const char* str){append(str);return *this;}void clear(){_str[0] = '\0';_size = 0;}void swap(string& s){std::swap(_str, s._str);std::swap(_size, s._size);std::swap(_capacity, s._capacity);}string substr(size_t pos,size_t len = npos){string s;int a = pos;if (len == npos || len >= _size){len = _size - pos;s.reserve(len);for (int i = pos; i < _size; i++){s += _str[i];}}else{s.reserve(len);for (int i = pos; i < pos + len; i++){s += _str[i];}}return s;}string& insert(size_t pos,size_t len,char c){assert(pos <= _size);if (_size + len > _capacity){reserve(_size + len);}int a = _size;while (a >= (int)pos){_str[a + len] = _str[a];a--;}int i = pos;while (i < pos+len){_str[i] = c;i++;}_size++;return *this;}string& insert(size_t pos, const char* str){int len = strlen(str);assert(pos <= _size);if (_size + len > _capacity){reserve(_size + len);}int a = _size;while (a >= (int)pos){_str[a + len] = _str[a];a--;}int i = pos;int j = 0;while (i < pos + len){_str[i] = str[j];i++;j++;}_size += len;return *this;}size_t size()const{return _size;}size_t capacity()const{return _capacity;}const char*c_str()const{return _str;}bool empty()const{return _size == 0;}void resize(size_t n, char c = '\0'){if (n < _size){_str[n] = '\0';_size = n;}if (n > _size){reserve(n);while (_size < n){_str[_size] = c;_size++;}_str[_size] = '\0';}}char operator[](size_t index){assert(index < _size);return _str[index];}const char& operator[](size_t index)const{assert(index < _size);return _str[index];}bool operator<(const string& s){int num1 = 0;int count = 0;while (num1<_size && num1 < s._size){if (_str[num1] > s._str[num1])return false;if (_str[num1] < s._str[num1])count++;num1++;}if (s._str[num1] != '\0')return true;if (count == 0)return false;return true;}bool operator==(const string& s){int num1 = 0;while (num1 < _size && num1 < s._size){if (_str[num1] != s._str[num1]){return false;}num1++;}if (s._str[num1] != '\0'||_str[num1]!='\0')return false;return true;}bool operator<=(const string& s){return *this == s || *this < s;}bool operator>(const string& s){return !(*this <= s);}bool operator>=(const string& s){return *this == s || *this > s;}bool operator!=(const string& s){return !(*this== s);}// 返回c在string中第一次出现的位置size_t find(char c, size_t pos = 0) const{int a = pos;while (a < _size){if (_str[a] == c)return a;a++;}return -1;}// 返回子串s在string中第一次出现的位置size_t find(const char* s, size_t pos = 0) const{int a = pos;int i = 0;while (a < _size){int j = a;while (_str[j] == s[i]){i++;j++;if (s[i] == '\0')return a;}i = 0;a++;}}// 删除pos位置上的元素string& erase(size_t pos, size_t len){if (len >= _size){_str[pos] = '\0';_size = pos;return *this;}int a = pos;while (a+len <= _size){_str[a] = _str[a + len];a++;}_size -= len;return *this;}const static size_t npos;
private:char* _str;size_t _size;size_t _capacity;
};
const size_t string::npos = -1;
ostream& operator<<(ostream& out, const string& s)
{for (auto a : s){cout << a;}return cout;
}
istream& operator>>(istream& in, string& s)
{s.clear();char ch;ch = in.get();while (ch!='\n'){s += ch;ch = in.get();}return in;
}
相关文章:
string
目录 六、STL简介 (一)什么是STL (二)STL的版本 (三)STL六大组件 七、string (一)标准库中的string 1、string类 2、string常用的接口 1)string类对象的常见构造 2)string类对象的容量操作 3)string类对象的访问及遍历操作 4)string类对象的修改操作 5)string类非成…...
html的日期选择插件
1.效果 2.文档 https://layui.gitee.io/v2/docs/ 3.引入 官网地址: https://layui.gitee.io/v2/ 引入(在官网下载,)jquery-1.7.2.min.js,layui/layui.js **<link href"js/layui/css/layui.css" rel"stylesh…...
OPPO哲库事件 “ 始末 ” ! 集体打哑谜?
1►OPPO哲库解散 2019 年,美国商务部以“科技网络安全”为由,将华为公司及其70家附属公司列入出口管制“实体名单”。与此同时,OPPO 创始人兼 CEO陈明永对外宣布,公司将为未来三年内投入 500 亿元用于前沿技术和深水区技术的探索…...
数据聚类分析
K均值 1.1 数据来源(随机生成) import matplotlib.pyplot as plt from sklearn.datasets import make_blobsX, y make_blobs(n_samples150,n_features2,centers3,cluster_std0.5,shuffleTrue,random_state0) # plt.scatter(X[:, 0], X[:, 1], cwhite, markero, edgecolorsbl…...
前 40 个 Microsoft Excel 面试问题答案
1)什么是 Microsoft Excel? Microsoft Excel 是一个电子电子表格应用程序,使用户可以使用按行和列细分的电子表格系统,使用公式存储,组织,计算和处理数据。 它还提供了使用外部数据库进行分析,…...
ros2学习笔记:shell环境变量脚本setup.bash[-z][-n][-f]参数作用
-n作用 [ -n 字符串 ] or [ 字符串 ] 字符串的长度为非零(有内容)则为真。加-n与不加-n结果相同。 -z作用 [ -z 字符串 ] 字符串的长度为零则为真。 字符串为空即NULL时为真,与上面的-n相反。 -f作用 [ -f FILE ] 如果 FILE 存在且是一…...
xss渗透(跨站脚本攻击)
一、什么是XSS? XSS全称是Cross Site Scripting即跨站脚本,当目标网站目标用户浏览器渲染HTML文档的过程中,出现了不被预期的脚本指令并执行时,XSS就发生了。 这里我们主要注意四点: 1、目标网站目标用户; 2、浏览…...
9参数化重采样时频变换,基于MATLAB平台,程序已调通,可直接替换数据进行分析。
参数化重采样时频变换,基于MATLAB平台,程序已调通,可直接替换数据进行分析。 9matlab参数化重采样时频变换 (xiaohongshu.com)...
RK3568平台开发系列讲解(调试篇)系统运行相关频率设置
🚀返回专栏总目录 文章目录 一、CPU 频率设置二、DDR 频率设置三、NPU 频率设置沉淀、分享、成长,让自己和他人都能有所收获!😄 📢 CPU 默认是 interactive 状态,它会根据 CPU 使用率和目标负载来动态地调整 CPU 频率。为获得更高运行速度或者性能评估,我们需要手动固…...
嵌入式:驱动开发 Day2
作业:字符设备驱动,完成三盏LED灯的控制 驱动代码: mychrdev.c #include <linux/init.h> #include <linux/module.h> #include <linux/fs.h> #include <linux/uaccess.h> #include <linux/io.h> #include &q…...
RK3399平台开发系列讲解(入门篇)VIM的基础命令
🚀返回专栏总目录 文章目录 一、Vim 命令速查二、其他命令三、Vim模式沉淀、分享、成长,让自己和他人都能有所收获!😄 📢 本篇将介绍Vim相关命令。 一、Vim 命令速查 简单说明一下,这张图上展示了一个键盘。图中的“•”表示,单个字母不是完整的命令,必须再有进一步…...
Rocky Linux 安装图解(替代centos)服务器+桌面
centos自从20年底转变为不稳定版本后,有很多替代方案 经过近3年的发展,rocky linux算是一个比较好的选择,一是依照red hat企业版来做,二是rocky的发起者也是centos的创始人 如果想安装debian,可以参考:deb…...
webpack 基础配置
常见配置 文件打包的出口和入口webpack如何开启一台服务webpack 如何打包图片,静态资源等。webpack 配置 loader配置 plugin配置sourceMap配置 babel 语法降级等 接下来 , 我们先从webpack的基本配置 开始吧! 在准备 配置之前 , 搭建一个 …...
C语言和mfc按格式读取文件数据
fscanf()函数的功能是从文件中按格式读取一个或多个数据; 例如文件中有一行数据, 22 3.34 hello 则使用 fscanf(fp, "%d%f%s", &a, &f, str) 可一次读取整型、浮点、字符串三个数据; 此函数位于C标准库头文件<stdio…...
SQLyog 各版本下载与安装(目前最新版本为13.2.0)
文章目录 一、SQLyog Ultimate 各版本下载1. For Windows x642. For Windows x86 二、SQLyog Community 各版本下载1. For Windows x642. For Windows x863. For Linux x86_644. For Linux i386 三 、SQLyog 安装四、如何解决SQLyog试用期到期问题五、最后 数据库可视化工具&am…...
CopyOnWrite 容器
CopyOnWrite容器是Java并发包中提供的一种特殊类型的集合,它的特点是在进行修改操作时不会修改原始容器,而是创建一个新的容器副本进行修改,这样可以避免并发修改异常(ConcurrentModificationException)。 主要的CopyOnWrite容器包括: CopyOnWriteArrayList:这是一个基…...
云服务部署:AWS、Azure和GCP比较
🌷🍁 博主猫头虎(🐅🐾)带您 Go to New World✨🍁 🦄 博客首页——🐅🐾猫头虎的博客🎐 🐳 《面试题大全专栏》 🦕 文章图文…...
Linux安装Ansible管理工具
条件情况说明 准备4台机器,是单master集群安装 192.168.186.128 ansible 192.168.186.129 node1 192.168.186.130 node2 192.168.186.131 node3 #永久修改主机名 hostnamectl set-hostname ansible && bash #在ansible上操作 hostnamectl set-hostname n…...
七天学会C语言-第二天(数据结构)
1. If 语句: If 语句是一种条件语句,用于根据条件的真假执行不同的代码块。它的基本形式如下: if (条件) {// 条件为真时执行的代码 } else {// 条件为假时执行的代码 }写一个基础的If语句 #include<stdio.h> int main(){int x 10;…...
高级功能的PID控制器在电离规等真空计线性化处理中的应用
摘要:针对高真空度用皮拉尼计和电离规信号的非线性和线性两种输出规格,为改进高真空度的测量和控制精度,本文提出了线性化处理的解决方案。解决方案的关键是采用多功能超高精度的真空压力控制器,具体内容一是采用控制器自带的最小…...
Vim 调用外部命令学习笔记
Vim 外部命令集成完全指南 文章目录 Vim 外部命令集成完全指南核心概念理解命令语法解析语法对比 常用外部命令详解文本排序与去重文本筛选与搜索高级 grep 搜索技巧文本替换与编辑字符处理高级文本处理编程语言处理其他实用命令 范围操作示例指定行范围处理复合命令示例 实用技…...
使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式
一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明:假设每台服务器已…...
Python爬虫实战:研究MechanicalSoup库相关技术
一、MechanicalSoup 库概述 1.1 库简介 MechanicalSoup 是一个 Python 库,专为自动化交互网站而设计。它结合了 requests 的 HTTP 请求能力和 BeautifulSoup 的 HTML 解析能力,提供了直观的 API,让我们可以像人类用户一样浏览网页、填写表单和提交请求。 1.2 主要功能特点…...
MMaDA: Multimodal Large Diffusion Language Models
CODE : https://github.com/Gen-Verse/MMaDA Abstract 我们介绍了一种新型的多模态扩散基础模型MMaDA,它被设计用于在文本推理、多模态理解和文本到图像生成等不同领域实现卓越的性能。该方法的特点是三个关键创新:(i) MMaDA采用统一的扩散架构…...
多模态商品数据接口:融合图像、语音与文字的下一代商品详情体验
一、多模态商品数据接口的技术架构 (一)多模态数据融合引擎 跨模态语义对齐 通过Transformer架构实现图像、语音、文字的语义关联。例如,当用户上传一张“蓝色连衣裙”的图片时,接口可自动提取图像中的颜色(RGB值&…...
Linux --进程控制
本文从以下五个方面来初步认识进程控制: 目录 进程创建 进程终止 进程等待 进程替换 模拟实现一个微型shell 进程创建 在Linux系统中我们可以在一个进程使用系统调用fork()来创建子进程,创建出来的进程就是子进程,原来的进程为父进程。…...
蓝桥杯 冶炼金属
原题目链接 🔧 冶炼金属转换率推测题解 📜 原题描述 小蓝有一个神奇的炉子用于将普通金属 O O O 冶炼成为一种特殊金属 X X X。这个炉子有一个属性叫转换率 V V V,是一个正整数,表示每 V V V 个普通金属 O O O 可以冶炼出 …...
IP如何挑?2025年海外专线IP如何购买?
你花了时间和预算买了IP,结果IP质量不佳,项目效率低下不说,还可能带来莫名的网络问题,是不是太闹心了?尤其是在面对海外专线IP时,到底怎么才能买到适合自己的呢?所以,挑IP绝对是个技…...
【Linux手册】探秘系统世界:从用户交互到硬件底层的全链路工作之旅
目录 前言 操作系统与驱动程序 是什么,为什么 怎么做 system call 用户操作接口 总结 前言 日常生活中,我们在使用电子设备时,我们所输入执行的每一条指令最终大多都会作用到硬件上,比如下载一款软件最终会下载到硬盘上&am…...
【无标题】湖北理元理律师事务所:债务优化中的生活保障与法律平衡之道
文/法律实务观察组 在债务重组领域,专业机构的核心价值不仅在于减轻债务数字,更在于帮助债务人在履行义务的同时维持基本生活尊严。湖北理元理律师事务所的服务实践表明,合法债务优化需同步实现三重平衡: 法律刚性(债…...

