C++STL(一)——string类
目录
- 一、string的定义方式
- 二、 string类对象的容量操作
- 三、string类对象的访问及遍历操作
- 四、string类对象的修改操作
- 五、string类非成员函数
一、string的定义方式
string是个管理字符数组的类,其实就是字符数组的顺序表。
它的接口也是非常多的。本章介绍一些常见使用如文档
string类实现了多个构造函数的重载,常用的构造函数如下
```
default (1) string(); //无参构造copy (2) string (const string& str); //拷贝str所指的字符序列substring (3) string(const char* string& str, size_t pos,size_t len =npos); //拷贝str字符串的第pos到最后一个字符from c-string (4) string (const char* s); //用C-string来构造string类对象,有'\0'string(const string& s); //拷贝构造from sequence (5) string (const char* s, size_t n); //拷贝s字符串的前n个进行初始化fill (6) string (size_t n, char c); //string类对象中包含n个字符c```
使用示例
//常用
string s1; //无参构造
string s2("羚羊"); //带参构造
string s3("this is a little sheep"); //带参构造
string s4(s2); //拷贝构造//了解
string s5(7, '#'); //生成7个'#'字符的字符串
string s6(s3, 0, 3); //从s3字符串第0下标拷贝3个字符
string s7(s3, 9); //从s3字符串第8下标拷贝到结尾
二、 string类对象的容量操作
| 函数名称 | 功能 |
|---|---|
| size(重点) | 返回字符串有效字符长度 |
| length | 返回字符串有效字符长度 |
| capacity | 返回空间总大小 |
| max_capacity | 返回最大空间 |
| empty (重点) | 检测字符串释放为空串,是返回true,否则返回false |
| clear (重点) | 清空有效字符 |
| reserve (重点) | 为字符串预留空间** |
| resize (重点) | 将有效字符的个数该成n个,多出的空间用字符c填充 |
int main()
{string s1("hello world");//在string类里等价,常用sizecout << s1.size() << endl;cout << s1.length() << endl;//根据编译器的不同结果也不同cout << s1.max_size() << endl; cout << s1.capacity() << endl;cout << s1.size() << endl;cout << s1.capacity() << endl;s1.clear();cout << s1.size() << endl; //只清理字符数据cout << s1.capacity() << endl; //不清理空间string s2("hello c++");//开空间,知道一共需要多少空间一次性开好空间后续就不需要扩容了//缩容是重新拷贝一块空间把数据拷贝进去,释放掉原空间s2.reserve(100);cout << s2.size() << endl;cout << s2.capacity() << endl;//开空间+初始化默认\0s2.resize(100, 'x'); //也可选定初始化字符cout << s2.size() << endl;cout << s2.capacity() << endl;s2.resize(20); //如果只要前20个,把后面数据清掉cout << s2.size() << endl;cout << s2.capacity() << endl;//empty是string的判空函数,我们可以调用strcmp函数来实现,strcmp函数是用于比较两个字符串大小的函数,当两个字符串相等时返回0。bool empty(){return strcmp(_str, "") == 0;}return 0;
}
三、string类对象的访问及遍历操作
迭代器在任何容器中都是相通的,虽然各个容器结构不一样,但在用法上都是通用的。
iterator是像指针一样的类型,iterator提供了一种统一的方式访问和修改容器的数据,算法就可以通过迭代器去处理容器中数据。
//正向迭代器
iterator
const iterator
//反向迭代器
reverse_iterator
const_reverse_iterator
| 函数名称 | 功能 |
|---|---|
| operator[] (重点) | 返回pos位置的字符,const string类对象调用 |
| begin+ end | begin获取第一个字符的迭代器 + end获取最后一个字符下一个位置的迭代器 |
| rbegin + rend | rbegin获取最后一个有效字 符的迭代器 + rend获取第一个字符下一个位置的迭代器 |
| 范围for | C++11支持更简洁的范围for的新遍历方式 |
#include<iostream>
#include<string>
using namespace std;int main()
{//[]运算符重载(可读可写)//[ ]运算符的重载是为了让string对象能像C字符串一样,通过[ ] +下标的方式获取字符串对应位置的字符char& operator[](size_t i) //只读const char& operator[](size_t i)const{assert(i < _size); //检测下标的合法性return _str[i]; //返回对应字符}string s;string s1("hello world");cout << s1 << endl; //普通直接打印//1. 下标+[]遍历,可对字符之间做控制和修改for (int i = 0; i < s1.size(); i++){s1[5] = '-'; //下标5的位置改为-cout << s1[i] << ' ';}cout << endl;//2.迭代器string::iterator it = s1.begin();while (it != s1.end()){cout << *it++ << ' ';}cout << endl;//3.范围for,其实底层就是迭代器for (auto ch : s1){cout << ch << ' ';}cout << endl;//逆置数组string s2("hello world");//写法等价auto rit = s2.rbegin(); //auto可自动识别类型string::reverse_iterator rit = s2.rbegin();while (rit != s2.rend()){cout << *rit++ << " ";}return 0;
}
四、string类对象的修改操作
| 函数名称 | 功能 |
|---|---|
| push_back | 在字符串后尾插字符c |
| insert | 插入字符或字符串 |
| append | 在字符串后追加一个字符串 |
| assign | 覆盖写入字符串 |
| erase | 删除字符 |
| operator= | 重载后该运算符支持string类的赋值、字符串的赋值以及字符的赋值 |
| operator+= (重点) | 在字符串后追加字符串str |
| c_str | 返回C格式字符串 |
| find + npos | 从字符串pos位置开始往后找字符c,返回该字符在字符串中的位置 |
| rfind | 从字符串pos位置开始往前找字符c,返回该字符在字符串中的位置 |
| substr | 在str中从pos位置开始,截取n个字符,然后将其返回 |
+=运算符的重载是为了实现字符串与字符、字符串与字符串之间能够直接使用+=运算符进行尾插。
+=运算符实现字符串与字符之间的尾插直接调用push_back函数即可。
1、使用push_back进行尾插
int main()
{string s1("hello");s1.push_back(' '); //插入字符s1.push_back('c');s1.push_back('p');s1.push_back('p');cout << s1 << endl; //hello cppreturn 0;
}
2、使用insert、append、assign插入
int main()
{string s1("hello world");//追加s1.append("abcde");cout << s1 << endl; //hello worldabcdes1.assign("1234567");cout << s1 << endl; //覆盖如上内容改为1234567//string& insert (size_t pos, const string& str);s1.insert(0, "hello"); //第0位置插入hellos1.insert(5, "world"); //第5位置插入worldcout << s1 << endl; //helloworld1234567//string& insert (size_t pos, size_t n, char c);s1.insert(0, 7, 'x'); //第0字符插入7个x字符cout << s1 << endl; //xxxxxxxhelloworld1234567//void insert (iterator p, size_t n, char c);s1.insert(s1.begin()+7, 7, 'y'); //第7个位置插入7个x字符cout << s1 << endl; //xxxxxxxyyyyyyyhelloworld1234567
}
3.使用erase删除
int main()
{string s1("hello world");s1.erase(5, 1); //下标第5个位置删除一个字符cout << s1 << endl;s1.erase(5); //下标5之后都删除string s2("hello world");//两个写法头删s2.erase(0, 1);s2.erase(s2.begin());
}
4.截取网站每个部分
int main()
{string url = "https://cplusplus.com/reference/string/string/?kw=string";size_t pos1 = url.find("://");string protocaol;if (pos1 != string::npos){protocaol = url.substr(0, pos1);}cout << protocaol << endl;string domain;string uri;size_t pos2 = url.find('/',pos1+3);if (pos2 != string::npos){domain = url.substr(pos1 + 3, pos2 - (pos1 + 3));uri = url.substr(pos2 + 1);}cout << domain << endl;cout << uri << endl;
}
5.+和+=
int main()
{string s1;string s2("hello");//支持string类的赋值s1 = s2;cout << s1 << endl; //hello//支持字符串的赋值s1 = "world";cout << s1 << endl; //world//支持字符的赋值s1 = 'x';cout << s1 << endl; //xstring s3;string s4("hello");//支持string类的复合赋值s3 += s4;cout << s1 << endl; //hello//支持字符串的复合赋值s3 += " world";cout << s3 << endl; //hello world//支持字符的复合赋值s3 += '!';cout << s4 << endl; //hello world!return 0;
}
五、string类非成员函数
| operator+ | 尽量少用,因为传值返回,导致深拷贝效率低 |
|---|---|
| operator>> (重点) | 输入运算符重载 |
| operator<< (重点) | 输出运算符重载 |
| getline (重点) | 获取一行字符串 |
| relational operators (重点) | 大小比较 |
1.string类中也对>>和<<运算符进行了重载,这就是为什么我们可以直接使用>>和<<对string类进行输入和输出的原因。
istream& operator>> (istream& is, string& str);
ostream& operator<< (ostream& os, const string& str);
int main()
{string s;cin >> s; //输入cout << s << endl; //输出return 0;
}
2.string类中还对一系列关系运算符进行了重载,它们分别是==、!=、<、<=、>、>=。重载后的关系运算符支持string类和string类之间的关系比较、string类和字符串之间的关系比较、字符串和string类之间的关系比较。
int main()
{string s1("abcd");string s2("abde");cout << (s1 > s2) << endl; //0cout << (s1 < s2) << endl; //1cout << (s1 == s2) << endl; //0return 0;
}
这些重载的关系比较运算符所比较的都是对应字符的ASCII码值。
3.使用>>进行输入操作时,当>>读取到空格便会停止读取,我们将不能用>>将一串含有空格的字符串读入到string对象中。
用法1
可以用getline函数完成一串含有空格的字符串的读取操作。
istream& getline (istream& is, string& str);
getline函数将从is中提取到的字符存储到str中,直到读取到换行符’\n’为止。
int main()
{string s;getline(cin, s); //输入:hello worldcout << s << endl; //输出:hello worldreturn 0;
}
用法2
istream& getline (istream& is, string& str, char delim);
getline函数将从is中提取到的字符存储到str中,直到读取到分隔符delim或换行符’\n’为止。
int main()
{string s;getline(cin, s, 'l'); //输入:hello worldcout << s << endl; //输出:hello worreturn 0;
}
相关文章:
C++STL(一)——string类
目录 一、string的定义方式二、 string类对象的容量操作三、string类对象的访问及遍历操作四、string类对象的修改操作五、string类非成员函数 一、string的定义方式 string是个管理字符数组的类,其实就是字符数组的顺序表。 它的接口也是非常多的。本章介绍一些常…...
机器学习--1.KNN机器学习入门
1、机器学习概述 1.1、什么是机器学习 机器学习(Machine Learning)是人工智能(Artificial Intelligence)领域的一个子集,它主要关注如何让计算机系统通过经验学习(数据)并自动改进性能。机器学…...
Adaptive LLM Transformer²
看到了一个不错的论文https://arxiv.org/pdf/2501.06252 TRANSFORMER-SQUARED: SELF-ADAPTIVE LLMS 挺有意思的,是一家日本AI公司SakanaAI的论文(我以前写过他们的不训练提升模型的能力的文章,感兴趣可以去翻)它家有Lion Jones坐镇…...
三路排序算法
三路排序算法 引言 排序算法是计算机科学中基础且重要的算法之一。在数据分析和处理中,排序算法的效率直接影响着程序的执行速度和系统的稳定性。本文将深入探讨三路排序算法,包括其原理、实现和应用场景。 一、三路排序算法的原理 三路排序算法是一…...
代码随想录day27
669. /** lc appleetcode.cn id669 langcpp** [669] 修剪二叉搜索树*/// lc codestart /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(nullptr) {}…...
基于LabVIEW的Modbus-RTU设备通信失败问题分析与解决
在使用 LabVIEW 通过 Modbus-RTU 协议与工业设备进行通信时,可能遇到无法正常发送或接收指令的问题。常见原因包括协议参数配置错误、硬件连接问题、数据帧格式不正确等。本文以某 RGBW 控制器调光失败为例,提出了一种通用的排查思路,帮助开发…...
1. 【.NET 8 实战--孢子记账--从单体到微服务--转向微服务】--前言
在我们的专栏《单体开发》中,我们实现了一个简单的记账软件的服务端,并且成功上线。随着用户数量的不断增长,问题逐渐开始显现。访问量逐渐增加,服务端的压力也随之加大。随着访问量的攀升,服务端的响应时间变得越来越…...
直方图:摄影中的视觉数据指南
目录 一、直方图基础:揭开它的神秘面纱 二、解读直方图类型:亮度与色彩的密码 (一)亮度直方图 (二)RGB 直方图 三、拍摄中巧用直方图:优化曝光与效果 (一)精准判断曝…...
一份完整系统化提升信息输出密度与逻辑严谨性的训练素材
一、方法 1. 理论基础与核心概念 1.1 信息输出密度 定义 信息输出密度可以理解为单位表达中所包含的有效信息量。它要求在有限的篇幅或时间内传递更多有价值、低冗余的信息。衡量指标 信息熵(Shannon Entropy):在信息论中,信息…...
CommonJS 和 ES6module 的区别
动态与静态 CommonJS 与 ES6 Module 最本质的区别在于前者对模块依赖的解决是“动态的”,而后者是“静态的”。在这里“动态”的含义是,模块依赖关系的建立发生在代码运行阶段:而“静态”则表示模块依赖关系的建立发生在代码编译阶段。 看一…...
IM 即时通讯系统-51-MPush开源实时消息推送系统
IM 开源系列 IM 即时通讯系统-41-开源 野火IM 专注于即时通讯实时音视频技术,提供优质可控的IMRTC能力 IM 即时通讯系统-42-基于netty实现的IM服务端,提供客户端jar包,可集成自己的登录系统 IM 即时通讯系统-43-简单的仿QQ聊天安卓APP IM 即时通讯系统-44-仿QQ即…...
前端 | JavaScript中的reduce方法
1. 什么是reduce reduce 方法是 JavaScript 中数组的重要方法之一,用于对数组中的元素进行累积计算。它接收一个回调函数作为参数,并返回一个最终计算结果。reduce 在许多场景下都非常有用,比如求和、数组扁平化、对象计数、数据转换等。 2…...
【Linux】从硬件到软件了解进程
个人主页~ 从硬件到软件了解进程 一、冯诺依曼体系结构二、操作系统三、操作系统进程管理1、概念2、PCB和task_struct3、查看进程4、通过系统调用fork创建进程(1)简述(2)系统调用生成子进程的过程〇提出问题①fork函数②父子进程关…...
2024-我的学习成长之路
因为热爱,无畏山海...
机试题——到邻国目标城市的最短距离
题目描述 A国与B国是相邻的两个国家,每个国家都有很多城市。国家内部有很多连接城市的公路,国家之间也有很多跨国公路,连接两个国家的边界城市。两个国家一共有N个城市,编号从1到N,一共有M条公路,包括国内…...
连续预测、
一、连续预测 调用模型遍历需要预测文件夹中的图片: image_ids open(‘VOCdevkit/VOC2007/ImageSets/Main/test.txt’).read().strip().split() for image_id in tqdm(image_ids): # 遍历测试图像 image_path “./VOCdevkit/VOC2007/JPEGImages/” image_id …...
Kamailio 不通过 dmq 实现注册复制功能
春节期间找到一篇文章,需要 fg 才能看到: https://medium.com/tumalevich/kamailio-registration-replication-without-dmq-65e225f9a8a7 kamailio1 192.168.56.115 kamailio2 192.168.56.116 kamailio3 192.168.56.117 route[HANDLE_REPLICATION] {i…...
002 mapper代理开发方式-xml方式
文章目录 代理xml方式UserMapper.javaUser.javadb.propertiesSqlMapConfig.xmlUserMapper.xmlUserMapperTest.javapom.xml 代理 此处使用的是JDK的动态代理方式,延迟加载使用的cglib动态代理方式 代理分为静态代理和动态代理。此处先不说静态代理,因为…...
大模型系列21-AI聊天机器人
聊天机器人 背景机器学习基础监督学习(Supervised Learning)概念应用场景主要问题 无监督学习(Unsupervised Learning)概念常见方法应用场景 强化学习(Reinforcement Learning)概念关键要素应用场景 模型优…...
Apache Iceberg数据湖技术在海量实时数据处理、实时特征工程和模型训练的应用技术方案和具体实施步骤及代码
Apache Iceberg在处理海量实时数据、支持实时特征工程和模型训练方面的强大能力。Iceberg支持实时特征工程和模型训练,特别适用于需要处理海量实时数据的机器学习工作流。 Iceberg作为数据湖,以支持其机器学习平台中的特征存储。Iceberg的分层结构、快照…...
25.2.3 【洛谷】作为栈的复习不错(学习记录)
今天学习的东西不算多,放了一个星期假,感觉不少东西都没那么清楚,得复习一下才行。今天搞个栈题写,把栈复习一下,明天进入正轨,边复习边学习新东西,应该会有二叉树的学习等等... 【洛谷】P1449 …...
Windows 中的 WSL:开启你的 Linux 之旅
今天在安装windows上安装Docker Desktop的时候,遇到了WSL。下面咱们就学习下。 欢迎来到涛涛聊AI 一、什么是 WSL? WSL,全称为 Windows Subsystem for Linux,是微软为 Windows 系统开发的一个兼容层,它允许用户在 Win…...
二维前缀和:高效求解矩阵区域和问题
在处理二维矩阵时,频繁计算某一子矩阵的和是一个常见的操作。传统的做法是直接遍历该子矩阵,时间复杂度较高。当矩阵非常大且有大量的查询时,直接计算将变得低效。为了提高效率,我们可以通过 二维前缀和 技巧在常数时间内解决这个…...
音视频入门基础:RTP专题(5)——FFmpeg源码中,解析SDP的实现
一、引言 FFmpeg源码中通过ff_sdp_parse函数解析SDP。该函数定义在libavformat/rtsp.c中: int ff_sdp_parse(AVFormatContext *s, const char *content) {const char *p;int letter, i;char buf[SDP_MAX_SIZE], *q;SDPParseState sdp_parse_state { { 0 } }, *s1…...
Android开发工作经历整理
一.无人机应用软件开发 集成大疆官网的DJIMobileSDK到AS中编写软件,操控无人机执行多个航点任务。集成OpenCV库进行图像识别,通过获取参数,根据算法执行sdk,使无人机降落到机库,并执行后续的换电操作。待无人机就绪后…...
C++中常用的十大排序方法之4——希尔排序
成长路上不孤单😊😊😊😊😊😊 【😊///计算机爱好者😊///持续分享所学😊///如有需要欢迎收藏转发///😊】 今日分享关于C中常用的排序方法之4——希尔排序的相…...
解决注入线程池的栈溢出问题
文章目录 1.问题产生2.问题解决 1.问题产生 在使用sleuth的时候,需要注入线程池,他才会自动包装,实现traceId的传递,但是突然启动时出现了栈溢出的问题 2.问题解决 根据报错,发现是Gson序列化相关的问题,…...
自动驾驶---两轮自行车的自主导航
1 背景 无人驾驶汽车最早出现在DARPA的比赛中,从那个时刻开始,逐渐引起全球学者的注意,于是从上个世纪开始各大高校院所开始了无人汽车的研发。直到这两年,无人驾驶汽车才开始走进寻常百姓家,虽然目前市面上的乘用车还…...
哈夫曼树并查集
(1)哈夫曼树 特殊概念: 1.结点的权:表示结点树的重要性 2.带权路径长度:从树的根到该节点的路径长度(经过的边数)与该节点上权值的乘积 2.树的带权路径长度:该树的所有叶子节点的…...
PyTorch数据建模
回归分析 import torch import numpy as np import pandas as pd from torch.utils.data import DataLoader,TensorDataset import time strat = time.perf_counter()...
