C++STL中string详解(零基础/小白,字符串)

目录

1. 基本概念:

1.1 本质:

1.2 string和char*区别:

1.3 特点:

2. 构造函数(初始化)

3. 赋值操作

4. 字符串拼接

5 查找 和 替换

6. 字符串比较

7. 字符存取

8. 插入和删除

9. 子串获取


1. 基本概念:

1.1 本质:

        string是C++风格的字符串,而string本质是一个类。

1.2 string和char*区别:

        char* 是一个指针。

        string是一个类,类内部封装了char*,管理这个字符串,是一个char*型的容器。

1.3 特点:

        string类内部封装了很多成员方法。

        例如:查找:find,拷贝copy,删除delete,替换replace,插入insert

        string管理char*所分配的空间,不用担心赋值越界和取值越界的问题,有类内部负责。

2. 构造函数(初始化)

        接下来都是先展示一下函数原型,具体如何操作将展示在代码中,如果看不懂函数原型,不要紧,直接看代码展示即可,学会怎么使用才是关键。当然要不需要去背,使用多了,自然记住了,并且记住的就是那些经常被使用的重要的。

初始化:

1. string();        //创建一个空的字符串

2. string(const char* s);            //使用字符串s初始化

3. string(const sting& str);        //使用一个string对象初始化另一个string对象

4. string(int n ,char c);              //使用n个字符c初始化

	// 第一种方法 创建空字符串string s1;	//第二种    使用字符串s初始化string对象const char* s = "hello world";string s2(s);cout << s2 << endl;//第三种    使用一个string对象初始化另一string对象string s3(s2);cout << s3 << endl;//第四种    将string初始化为n个字符cstring s4(10, 'a');cout << s4 << endl;

        

3. 赋值操作

赋值操作 : 给string字符串进行赋值
        一类:
            string& operator = (const char* s);
            string& operatot = (const string& s);
            sting&    operator = (char c);

        
        二类:

            string& assign(const string& s);
            string& assign(const char* s);
            string& assign(const char* s,int n);
            string& assign(int n,char c);

//一类://1.1string s1;s1 = "hello";cout << s1 << endl;//1.2string s2;s2 = s1;cout << s2 << endl;//1.3string s3;s3 = 'c';cout << s3 << endl;//二类://2.1string s4;s4.assign(s1);cout << s4 << endl;//2.2string s5;s5.assign("hello");cout << s5 << endl;//2.3string s6;s6.assign("hello", 3);cout << s6 << endl;//2.4string s7;s7.assign(5, 'h');cout << s7 << endl;

        其实初始化和赋值大部分都比较相似,熟悉了另一种就比较容易了。

        对于是否要全部掌握,= 和 assign函数,其实并不需要担心,目前你先只要熟练掌握其中一种就好了。

4. 字符串拼接

拼接操作 :  实现在字符串末尾拼接字符串
        一类:
        string& operator += (const char* s);
        string& operator += (const char c);
        string& operator += (const string& str);

        
        二类:
        string& append(const char* s);
        string& append(const char* s,int n);
        string& append(const string& str);
        string& append(const string& str,int pos,int n);

//第一类://1.1string s1;s1 += "hello ";cout << s1 << endl;//1.2s1 += 'C';cout << s1 << endl;//1.3string s2 = " !";s1 += s2;cout << s1 << endl;//第二类://2.1string s3 = "hello  ";s3.append("world");cout << s3 << endl;//2.2s3.append(s2);cout << s3 << endl;//2.3 s3.append("and C++", 7);cout << s3 << endl;//2.4s3.append(s1, 0, 5);cout << s3 << endl;

5 查找 和 替换

查找:查找指定字符串是否存在
        ——find 和 rfind的区别 :find从左往右查找,rfind从右往左查
        int find(const string& str,int pos);    查找str第一次出现的位置,从pos位置开始查找
        int find(const char* s,int pos);    查找s第一次出现的位置,从pos位置开始查找
        int find(const char* s,int pos,int n);    从pos位置查找s的前n个字符第一次位置
        int find(const char c,int pos);    查找字符c第一次出现的位置,从pos位置开始

替换:在指定的位置替换字符串
        string& replace(int pos,int n,const string& str);
        string& replace(int pos,int n,const char* s);

        这里我们并不会对所有的接口函数进行实现,只要把最常用的和一些需要注意的介绍一下,其他的留给你自己来实验。

        1. find查找字符或字符串:

        如果想从0位置开始,即pos=0,是可以省略的。

string str = "hello"
int pos1 = str.find("hel");
int pos2 = str.find('o');

        2. find从pos位置开始查找s的前n个字符出现的第一个位置

string str("hello string !");
int pos1 = str.find("strnig",0,3);
int pos2 = str.find("strnig",0,6);
cout<<pos1<<endl;
cout<<pos2<<endl;

        这里pos1为s的位置,而pos2为-1,因为str中没有strnig这个字符串,其中根本原因是n的不用,strnig这个字符串只有前3个字符出现在str中。

        3. replace替换字符串

string str1 = "hello world";
str1.replace(6,3,"C++");string str2 = "hello world";
str2.replace(6,5,"C++");

        这里替换就是将前n个元素替换成新的字符串,新的字符串不受n的影响,n只影响被替换的字符个数。当n=0时,在pos位置插入。

6. 字符串比较

比较方式:字符串比较是按字符的ASCII码进行对比

= 返回 0

> 返回 1

< 返回 -1

int compare(const string& str) ;

int compare(const char* s);

	string str1 = "hello";string str2 = "world";int com1 = str2.compare(str1);cout << com1 << endl;int com2 = str1.compare(str2);cout << com2 << endl;

7. 字符存取

string中单个字符存取方式有两种:

char& operator[](int n);        //通过[]防水取字符

char& at(int n);                //通过at方法获取字符

string str = "hello";
str[0] = 'w';
cout << str << endl;
str.at(0) = 'h';
cout << str << endl;

8. 插入和删除

插入:
string& insert(int pos,const char* s);        //插入字符串
string& insert(int pos,const string& str);        //插入字符串
string& insert(int pos,int n,char c);        //在指定位置插入n个字符c

删除:

string& erase(int pos,int n)           //删除从pos位置开始的n个字符

    string str1 = "hello ";str1.insert(6, "world");cout << str1 << endl;string str2 = " !";str2.insert(0, str1);cout << str2 << endl;string str3;str3.insert(0,3, 'a');cout << str3 << endl;str3.erase(0, 1);cout << str3 << endl;

9. 子串获取

从字符串中获取想要的子串

string substr(int pos,int n);        //返回由pos开始的n个字符组成的字符串

	string str = "abcdef";string substr = str.substr(1, 3);cout << "substr = " << substr << endl;


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

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

相关文章

字节与位在物联网传输协议中的使用

1个字节(byte) 8个位(bit) 如下例子&#xff0c;是一个上报数据类型的表格&#xff0c;总有48位(6个字节) 假如报文给的数据类型数据是&#xff1a; 0x06 时&#xff0c;06十六进制转为二进制&#xff0c;结果是00000110 那么在图下就是 (bit1 和 bit2 都为 1) &#xff…

[极客大挑战 2019]BuyFlag1

打开网站&#xff1a; 右上角有个菜单 (menu) &#xff0c;先点一下&#xff0c;然后就进入了 pay.php 页面。 其中关键信息如下&#xff1a; ## FlagFlag need your 100000000 money### attentionIf you want to buy the FLAG:You must be a student from CUIT!!!You must…

【离线】牛客小白月赛39 G

登录—专业IT笔试面试备考平台_牛客网 题意 思路 考虑离线Bit做法 这种离线Bit&#xff0c;一般都是去考虑二维数点就能写清楚了 确定好两维&#xff1a;x 轴是1 ~ n&#xff0c; y 轴是 k 的大小 然后去遍历值域&#xff0c;如果值域很大的话需要排序离散化&#xff0c;但…

RT-DETR 图片目标计数 | 特定目标进行计数

全类别计数特定类别计数如何使用 RT-DETR 进行对象计数 有很多同学留言说想学 RT-DETR 目标计数。那么今天这篇博客,我将教大家如何使用 RT-DETR 进行对象计数。RT-DETR 是一种非常强大的对象检测模型,它可以识别图像中的各种对象。我们将学习如何利用这个模型对特定对象进行…

如何拍摄超级大像素图片,超级大像素有哪些应用

引言&#xff1a; 在数字摄影领域&#xff0c;超级大像素照片是指通过高像素的相机或拼接多张照片合成的照片。这样的照片具有更高的分辨率&#xff0c;细节更加清晰&#xff0c;绘画质感更强。那么如何拍摄超级大像素照片&#xff0c;超级大像素可以用在哪些领域呢。 一&…

希尔伯特黄变换(hht)

提示&#xff1a;主要对希尔伯特黄变换进行简略的介绍 一、希尔伯特黄变换是什么&#xff1f; 1.1 定义 为了纪念故事中两位老先生&#xff08;Hilbert和Huang&#xff09;的突出贡献&#xff0c;人们决定把“经过EMD分解出的IMF分量再经过Hilbert变换&#xff0c;最终得到信…

扫地机器人测试点

简介&#xff1a;在科技发展的浪潮下&#xff0c;扫地机器人已经成为越来越多家庭的“贴心管家”&#xff0c;助力我们迎战尘埃和杂物。但是&#xff0c;面对市面上五花八门的扫地机器人&#xff0c;以下为一般情况下扫地机器人的功能测试要点。 历史攻略&#xff1a; AI语音…

Vue3-19-组件-定义和基本使用

组件的定义 个人理解 &#xff1a;1、组件&#xff0c;就是我们把某个功能模块进行封装&#xff0c;在使用时直接引入进行使用&#xff0c;极大的提高了代码的可复用性。2、在vue 中&#xff0c;一个 [.vue] 文件&#xff0c;就是一个组件。3、组件之间存在【引入】 与 【被引…

Golang在 Docker 中交叉编译 Windows

前言&#xff1a; 前端时间把本地的 Golang 开发环境卸载了&#xff0c;如果编写代码的话就是启动一个 Golang 的 Docker 容器。这样做对于服务端开发本来也是没有问题的&#xff0c;但是有时候想要把程序放到 Windows 上面来执行&#xff0c;那就遇到麻烦了。因为 Docker 容器…

MSP430x44x Terminal Functions使用说明

DVcc1 1 I/O ADC中参考电压正极端子的输出 P6.3/A3 2 I/O 通用数字I/O/模拟输入a3--12位ADC P6.4/A4 3 I/O 通用数字I/O/模拟输入a4--12位ADC P6.5/A5 4 I/O 通用数字I/O/模拟输入a5--12位ADC P6.6/A6 5 I/O 通用数字I/O/模拟输入a6--12位ADC P6.7/A7/SVSI…

文件上传自动化测试方案(超详细)

一、概述 【测试地址】&#xff1a;https://pan.baidu.com 【测试工具】&#xff1a;selenium、requests 【脚本语言】&#xff1a;Python 【运行环境】&#xff1a;Windows 百度网盘作为文件存储及分享的平台&#xff0c;核心功能大部分是对文件的操作&#xff0c;如果要…

小红书可观测 Metrics 架构演进,如何实现数十倍性能提升?

在当前云原生时代&#xff0c;随着微服务架构的广泛应用&#xff0c;云原生可观测性概念被广泛讨论。可观测技术建设&#xff0c;将有助于跟踪、了解和诊断生产环境问题&#xff0c;辅助开发和运维人员快速发现、定位和解决问题&#xff0c;支撑风险追溯、经验沉淀、故障预警&a…