揭开C++ STL的神秘面纱之string:提升编程效率的秘密武器

news2024/10/26 2:41:54

目录

🚀0.前言

🚈1.string 构造函数

🚝1.1string构造函数

🚝1.2string拷贝构造函数

🚈2.string类的使用

🚝2.1.查询元素个数或空间

返回字符串中有效字符的个数:size lenth

返回字符串目前所占的空间:capacity  

检验有效字符个数是否为零:empty  

 🚝2.2对字符串容量操作

为字符串预留空间:reserve

将有效字符的个数该成n个,多出的空间用字符c填充:resize

  清空有效字符:clear

🚝2.3string类对象的访问及遍历操作

 2.3.1 [ ]访问

 2.3.2迭代器

 2.3.3反向迭代器

🚈3.增删查改等

🚝3.1增

在字符串后尾插字符c:push_back

 在字符串后追加一个字符串:append

 在字符串后追加字符串str(真香):operator+=

​编辑 插入:insert

 🚝3.2删

 在字符串后尾删除字符:pop_back

 在某处删除:erase

 🚝3.3查

从字符串pos位置开始往后找字符c,返回该字符在字符串中的位置:find

 从字符串pos位置开始往前找字符c,返回该字符在字符串中的位置:rfind

 🚝3.4改

 🚈4.其他

返回C格式字符串:c_str

在str中从pos位置开始,截取n个字符,然后将其返回:substr

​编辑

​编辑获取一行字符串:getline 

💎7.结束语


🚀0.前言

言C++之言,聊C++之识,以C++会友,共向远方。各位博友的各位你们好啊,这里是持续分享C++知识的小赵同学,今天要分享的C++知识是string ,在这一章,小赵将会向大家聊聊C++的string知识 。✊

🚈1.string 构造函数

🚝1.1string构造函数

 我们通过查阅网站得到string构造函数如上,我们主要使用的构造函数是下面这几个

string str1;//空字符串
cout << str1 << endl;
string str2("i love you");//直接传入字符串构造
cout << str2 << endl;
string str3(str2.begin(), str2.end());//利用迭代器去构造
cout << str3;

这三种构造方式都是相当不错的。这里我们可以通过底层看看string内部是如何去构造的;

 我们通过查看它的底层发现它好像就是一个动态数组,那么我们能不能这么用呢?当然是可以的。

 那么这个可以说是非常爽的了。

🚝1.2string拷贝构造函数

 这个我们用起来应该是相当熟悉了。

🚈2.string类的使用

🚝2.1.查询元素个数或空间

返回字符串中有效字符的个数:size lenth

	string str1("1024");
	cout << str1.size() << endl;//返回有效字符个数
	cout << str1.length() << endl;//返回有效字符个数

返回字符串目前所占的空间:capacity  

	cout << str1.capacity();//返回字符串目前所占的空间; 

为什么这里的空间和有效字符不一样呢?主要因为其实就和我们之前队列一样,str在最开始的时候也进行了开空间操作,而当里面的字符快要填满时会进行扩容操作。(这个在实现string时候我们还会讲) 

检验有效字符个数是否为零:empty  

需要注意的是这里指的是有效字符个数而不是所占空间

 🚝2.2对字符串容量操作

为字符串预留空间:reserve

	string s;
	cout << s.capacity() << endl;
	s.reserve(20);//告诉扩容函数我要放20个字符,你的不够用了,就快点扩容
	cout << s.capacity() << endl;

当然如果你输入的值小于当前空间一般是不会进行扩容的 。

将有效字符的个数该成n个,多出的空间用字符c填充:resize

	string s;
	s.resize(10);//将有效字符的个数该成10个,多出的空间用字符'\0'填充
	cout << s << endl;
	s.resize(20, 'a');//将有效字符的个数该成20个,多出的空间用字符'a'填充
	cout << s<<endl;

 这个函数其实内部也有开空间的函数(可能就是reverse),所以当你的字符大于目前的空间时候会给你扩容,然后填上。

resize(size_t n) 与 resize(size_t n, char c)都是将字符串中有效字符个数改变到n个,不同的是当字 符个数增多时:resize(n)用0来填充多出的元素空间,resize(size_t n, char c)用字符c来填充多出的 元素空间。注意:resize在改变元素个数时,如果是将元素个数增多,可能会改变底层容量的大 小,如果是将元素个数减少,底层空间总大小不变。  

  清空有效字符:clear

s.clear();//清空有效字符
cout << s.size();

需要注意的是这里只清理字符,不会缩减空间。

🚝2.3string类对象的访问及遍历操作

 2.3.1 [ ]访问

这个访问方式也是我们前面试过的,和数组一样就很爽。

 2.3.2迭代器

迭代器这里,我们可以当成指针一样先用着,等到实现的时候,我们就会知道里面是什么了。

	string::iterator it = s.begin();//这里要指定谁的迭代器
	while (it != s.end())
	{
		cout << *it;
		it++;
	}

 2.3.3反向迭代器

方向迭代器与正向迭代器相反。rbegin对应的就是end.

🚈3.增删查改等

🚝3.1增

在字符串后尾插字符c:push_back

	string s;
	s.push_back('a');//在结尾添加字符'a'
	cout << s;

 在字符串后追加一个字符串:append

虽然它的实现很多但是我们一般用的也就只有第一个也就是我圈红的那个。

	string s("hello");
	s.append(" 1024");
	cout << s << endl;

 在字符串后追加字符串str(真香):operator+=

这个是真香重载了+=使用非常爽。

	string s("hello ");
	s += "1024";
	cout << s<<endl;
	s += ' i';
	cout << s << endl;

 插入:insert

 插入我们也是非常熟悉了,以前就有

 我个人主要用的就是这一个,给位置插入;(其他的大家可以自己尝试去探索下)

	s.insert(0, "你好");
	cout << s << endl;

 🚝3.2删

 在字符串后尾删除字符:pop_back

	s.pop_back();//删除尾部字符
	cout << s << endl;

 在某处删除:erase

 这里我们也主要用第一个

	s.erase(0, 5);//从0位置开始删5个字符
	cout << s << endl;

 🚝3.3查

从字符串pos位置开始往后找字符c,返回该字符在字符串中的位置:find

 

	string s("abbba");
	size_t a=s.find("bb", 2);//从2位置开始向后找
	cout << a << endl;
	size_t b=s.find('a');//用缺省参数,即从0位置开始向后找
	cout << b<<endl;
	size_t c = s.find('a',3);
	cout << c;

 从字符串pos位置开始往前找字符c,返回该字符在字符串中的位置:rfind

npos即默认最后一个字符位置 

	string s("abbba");
	size_t b=s.rfind('a');//默认从最后一个位置向前找
	cout << b << endl;
	size_t c = s.rfind('a',2);//从2位置向前找
	cout << c << endl;

 🚝3.4改

其实改的话很简单就用我们之前的【】就行了,很香。

 

 🚈4.其他

返回C格式字符串:c_str

 

在str中从pos位置开始,截取n个字符,然后将其返回:substr

	string a = s.substr(2, 3);//从2位置开始拷贝3个字符,组成字符串返回
	cout << a<<endl;
	cout << s;

获取一行字符串:getline 

这个还是比较重要的,比如我们要读取的字符串中有空格就可以用这个。

大家可以先像我这样用着,这里的输入流参数(istream)到后面我们会说。

💎7.结束语

好了小赵今天的分享就到这里了,如果大家有什么不明白的地方可以在小赵的下方留言哦,同时如果小赵的博客中有什么地方不对也希望得到大家的指点,谢谢各位家人们的支持。你们的支持是小赵创作的动力,加油。

如果觉得文章对你有帮助的话,还请点赞,关注,收藏支持小赵,如有不足还请指点,方便小赵及时改正,感谢大家支持!!!

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

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

相关文章

micro-app【微前端实战】主应用 vue3 + vite 子应用 vue3+vite

micro-app 官方文档为 https://micro-zoe.github.io/micro-app/docs.html#/zh-cn/framework/vite 子应用 无需任何修改&#xff0c;直接启动子应用即可。 主应用 1. 安装微前端框架 microApp npm i micro-zoe/micro-app --save2. 导入并启用微前端框架 microApp src/main.ts …

2024软考网络工程师笔记 - 第8章.网络安全

文章目录 网络安全基础1️⃣网络安全威胁类型2️⃣网络攻击类型3️⃣安全目标与技术 &#x1f551;现代加密技术1️⃣私钥密码/对称密码体制2️⃣对称加密算法总结3️⃣公钥密码/非对称密码4️⃣混合密码5️⃣国产加密算法 - SM 系列6️⃣认证7️⃣基于公钥的认证 &#x1f552…

为微信小程序换皮肤之配置vant

微信小程序自带的控件虽然具有很好的通用性和简洁性&#xff0c;但在面对一些复杂的交互场景和个性化的设计需求时&#xff0c;可能会显得力不从心。其功能的相对基础使得开发者在实现诸如多步骤复杂表单提交、实时数据交互与可视化展示、高度定制化的界面布局等方面&#xff0…

Navicat 安装

Navicat 安装步骤

qt 下载安装

1. 官网地址 https://www.qt.io/ 2. 下载 使用邮箱注册账号&#xff0c;登录&#xff0c;后边安装时也用的到 登录后&#xff1a; 这里需要电话号验证&#xff0c;电话号需要正确的&#xff0c;其他随便填&#xff0c;电话号中国区前需要86&#xff0c; 验证后自动下载 …

[CSP-J 2023] 一元二次方程(模拟)

变态的大模拟…… 洛谷题目传送门https://www.luogu.com.cn/problem/P9750 解题思路 主要还是模拟&#xff0c;题目让你求啥你就求啥&#xff0c;要注意细节。 然后化简根式的可以用质因数分解一下即可。 代码 #include<bits/stdc.h> using namespace std; #define …

opencv 图像翻转- python 实现

在做图像数据增强时会经常用到图像翻转操作 flip。 具体代码实现如下&#xff1a; #-*-coding:utf-8-*- # date:2021-03 # Author: DataBall - XIAN # Function: 图像翻转import cv2 # 导入OpenCV库path test.jpgimg cv2.imread(path)# 读取图片 cv2.namedWindow(image,1) …

C++基础与实用技巧第三节:内存管理与性能优化

第二章&#xff1a;C基础与实用技巧 第三节&#xff1a;内存管理与性能优化 1. 动态内存的管理策略与技巧 动态内存管理是C编程的核心部分之一&#xff0c;合理管理内存可以极大提高程序的性能和稳定性。在C中&#xff0c;动态内存的分配和释放通常使用new和delete运算符&am…

LeetCode_2427. 公因子的数目_java

1、题目 2427. 公因子的数目https://leetcode.cn/problems/number-of-common-factors/ 给你两个正整数 a 和 b &#xff0c;返回 a 和 b 的 公 因子的数目。 如果 x 可以同时整除 a 和 b &#xff0c;则认为 x 是 a 和 b 的一个 公因子 。 示例 1&#xff1a; 输入&#x…

基于springboot企业微信SCRM管理系统源码带本地搭建教程

系统是前后端分离的架构&#xff0c;前端使用Vue2&#xff0c;后端使用SpringBoot2。 技术框架&#xff1a;SpringBoot2.0.0 Mybatis1.3.2 Shiro swagger-ui jpa lombok Vue2 Mysql5.7 运行环境&#xff1a;jdk8 IntelliJ IDEA maven 宝塔面板 系统与功能介绍 基…

实现prometheus+grafana的监控部署

直接贴部署用的文件信息了 kubectl label node xxx monitoringtrue 创建命名空间 kubectl create ns monitoring 部署operator kubectl apply -f operator-rbac.yml kubectl apply -f operator-dp.yml kubectl apply -f operator-crd.yml # 定义node-export kubectl app…

RHCE的练习(4)

多端口访问多网站 第一步&#xff1a; 关闭防火墙&#xff08;因为要与外部连接访问&#xff09; [rootlocalhost ~]# systemctl stop firewalld [rootlocalhost ~]# setenforce 0第二步&#xff1a; 创建新IP地址&#xff08;用于区分&#xff09; [rootlocalhost ~]# nmcli…

【南方科技大学】CS315 Computer Security 【Lab6 IoT Security and Wireless Exploitation】

目录 Introduction (Part 1: OS Security for IoT )Software RequirementsStarting the Lab 6 Virtual MachineSetting up the Zephyr Development EnvironmentDownload the Zephyr Source CodeInstalling Requirements and DependenciesSetting the Project’s Environment Va…

PoissonRecon学习笔记

1. Screened Poisson Reconstruction (SPR) 源码&#xff1a;https://github.com/mkazhdan/PoissonRecon However, as noted by several researchers, it suffers from a tendency to over-smooth the data. 泊松重建存在过度平滑的现象。 方法&#xff1a;position and gradi…

为Windows Terminal 配置zsh + Oh-My-Zsh!

参考&#xff1a; 为Windows Terminal 配置zsh Oh-My-Zsh! [非WSL] https://zhuanlan.zhihu.com/p/625583037 Package: zsh - MSYS2 Packages 安装配置 1、安装 Windows Terminal(必须) Method 1: 打开 Microsoft Store&#xff0c;搜索 “Windows Terminal”。点击 “…

Web应用框架-Django应用基础

1. 认识Django Django是一个用Python编写的开源高级Web框架&#xff0c; 旨在快速开发可维护和可扩展的Web应用程序。 使用Django框架的开发步骤&#xff1a; 1.选择合适的版本 2.安装及配置 3.生成项目结构 4.内容开发 5.迭代、上线、维护 Django官网&#xff1a; Djang…

开源表单生成器OpnForm

什么是 OpnForm &#xff1f; OpnForm 是一个开源的表单构建工具&#xff0c;旨在简化创建自定义表单的过程&#xff0c;特别适合无编码知识的用户。它通过人工智能优化表单创建流程&#xff0c;支持多种用途&#xff0c;如联系人表单、调查表等。OpnForm 提供了一个直观的拖放…

最优化方法-无约束优化算法(最速下降法)matlab实现

一、前言 最速下降法 &#xff0c;又称为梯度法&#xff0c;是一种无约束求解多元函数极小值的方法。最速下降法的起源可以追溯到19世纪&#xff0c;最早由数学家Cauchy在1847年提出。随着计算机技术的发展&#xff0c;最速下降法在20世纪50年代逐渐应用于各种优化问题&#x…

BD数字化装备车场:RFID技术的突破之道

传统的车库管理流程主要依赖手工方式&#xff0c;这无疑降低了作业效率&#xff0c;尤其在任务高峰期或紧急情况下&#xff0c;车库进出口的交通堵塞问题尤为突出。随着2023年的到来&#xff0c;我国相继发布了《交通强国建设纲要》与《数字中国建设整体布局规划》等关键政策文…

Uni-App-01

HBuilder安装卸载 安装 下载HBuilder最新版 解压到安装目录&#xff0c;路径中不要有中文和空格 在桌面上增加快捷方式 卸载 执行reset.bat 删除HBuilder文件夹&#xff08;如果提示文件被占用&#xff0c;杀死相关进程再删除&#xff09; 夜神模拟器安装 安装 下…