【C++】STL(二) string容器

一、string基本概念

1、本质

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

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

2、特点

1、string 类内部封装了很多成员方法
(例如:查找find,拷贝copy,删除delete 替换replace,插入insert)
2、string管理char*所分配的内存,不用担心复制越界和取值越界等,由类内部进行负责

3、string构造函数

① string构造函数原型

string(); // 创建一个空的字符串 例如:string str;
string(const char * s); // 使用字符串s初始化
string(const string & str); // 使用一个string对象初始化另一个string对象
string(int n,char c); //使用n个字符c初始化

② string的多种构造方式没有可比性,灵活使用即可。

例子

#include <iostream>
using namespace std;
#include<string> 

//string的构造函数

/*
构造函数原型:
    string();                   //创建一个空的字符串 例如: string str;
    string(const char* s);      //使用字符串s初始化
    string(const string& str);  //使用一个string对象初始化另一个string对象
    string(int n, char c);      //使用n个字符c初始化
*/

void stringtest01()
{
    string s1; //默认构造 就是空字符串

    const char *str = "lalalala";
    string s2(str); //使用字符串 s 初始化

    string s3(s2);

    string s4(5, 'a');

    cout << "s2 = " << s2 << endl;
    cout << "s3 = " << s3 << endl;
    cout << "s4 = " << s4 << endl;
}


int main()
{
    stringtest01();

    system("pause");

    return 0;
}

在这里插入图片描述

2.3 string赋值操作

① 给string字符串进行赋值。
② 赋值的函数原型

赋值的函数原型:
    string& operator=(const char* s);       //char*类型字符串 赋值给当前的字符串
    string& operator=(const string &s);     //把字符串s赋给当前的字符串
    string& operator=(char c);              //字符赋值给当前的字符串
    string& assign(const char *s);          //把字符串s赋给当前的字符串
    string& assign(const char *s, int n);   //把字符串s的前n个字符赋给当前的字符串
    string& assign(const string &s);        //把字符串s赋给当前字符串
    string& assign(int n, char c);          //用n个字符c赋给当前字符串

③ string的赋值方式很多,operator=这种方式是比较常用的。

例子

void stringtest02()
{
    string s1 = "cgslbdfapofclaujbrank!";
    cout << "s1 = " << s1 << endl;

    string s2;
    s2 = s1;    //把字符串s赋给当前的字符串
    cout << "s2 = " << s2 << endl;

    string s3;
    s3 = 'a';    //字符赋值给当前的字符串
    cout << "s3 = " << s3 << endl;

    string s4;
    s4.assign("vvvvvvvv");
    cout << "s4 = " << s4 << endl;

    string s5;
    s5.assign("abcdefghijklmn", 5);
    cout << "s5 = " << s5 << endl;

    string s6;
    s6.assign(s5);
    cout << "s6 = " << s6 << endl;

    string s7;
    s7.assign(9, 'a');
    cout << "s7 = " << s7 << endl;
}
int main()
{
    stringtest02();

    system("pause");

    return 0;
}

在这里插入图片描述

2.4 string字符串拼接— 实现在字符串末尾拼接字符串

① 实现在字符串末尾拼接字符串。

② 函数原型:

字符串拼接函数原型:
    string& operator+=(const char* str);              //重载+=操作符
    string& operator+=(const char c);                 //重载+=操作符
    string& operator+=(const string& str);            //重载+=操作符
    string& append(const char *s);                    //把字符串s连接到当前字符串结尾
    string& append(const char *s, int n);             //把字符串s的前n个字符连接到当前字符串结尾
    string& append(const string &s);                  //同operator+=(const string& str)
    string& append(const string &s, int pos, int n);  //字符串s中从pos开始的n个字符连接到字符串结尾

例子

void stringtest03()
{
    string s1 = "I";
    s1 += "abcd";
    cout << "s1 = " << s1 << endl;

    s1 += ':';
    cout << "s1 = " << s1 << endl;

    string s2 = "LKMN";
    s1 += s2;
    cout << "s1 = " << s1 << endl;

    s1.append("qwer");
    cout << "s1 = " << s1 << endl;

    s1.append("ty:uiop", 3);
    cout << "s1 = " << s1 << endl;

    s1.append(s2);
    cout << "s1 = " << s1 << endl;

    s1.append(s2, 1, 3);// 从下标1位置开始 ,截取3个字符,拼接到字符串末尾
    cout << "s1 = " << s1 << endl;
}
int main()
{
    stringtest03();

    system("pause");

    return 0;
}

在这里插入图片描述

2.5 string字符串查找和替换

① 查找:查找指定字符串是否存在。

② 替换:在指定的位置替换字符串。

③ 函数原型:

函数原型:
    int find(const string& str, int pos = 0) const;      //查找str第一次出现位置,从pos开始查找
    int find(const char* s, int pos = 0) const;          //查找s第一次出现位置,从pos开始查找
    int find(const char* s, int pos, int n) const;       //从pos位置查找s的前n个字符第一次位置
    int find(const char c, int pos = 0) const;           //查找字符c第一次出现位置

    int rfind(const string& str, int pos = npos) const;  //查找str最后一次位置,从pos开始查找
    int rfind(const char* s, int pos = npos) const;      //查找s最后一次出现位置,从pos开始查找
    int rfind(const char* s, int pos, int n) const;      //从pos查找s的前n个字符最后一次位置
    int rfind(const char c, int pos = 0) const;          //查找字符c最后一次出现位置

    string& replace(int pos, int n, const string& str);  //替换从pos开始n个字符为字符串str
    string& replace(int pos, int n,const char* s);       //替换从pos开始的n个字符为字符串s

④ find查找是从左往右,rfind从右往左。

⑤ find找到字符串后返回查找的第一个字符位置,找不到返回-1。

⑥ replace在替换时,要知道从哪个位置起,多少个字符,替换成什么样的字符串。

例子

void stringtest04()
{
    string s1 = "abcdefabcimnlkabcmnrsabcqrst";
    int pos = (int)s1.find("bc");
    cout << "找到字符串,位置POS : " << pos << endl;

    pos = (int)s1.rfind("bc");
    cout << "找到字符串,位置POS : " << pos << endl;

    s1.replace(1, 3, "1111");    //从1号位置起后面4个字符替换为 1111 
    cout << "S1 = " << s1 << endl;
}
int main()
{
    stringtest04();

    system("pause");

    return 0;
}

在这里插入图片描述

2.6 string字符串比较

① 功能描述:字符串之间比较。

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

比较方式:
    字符串比较是按字符的ASCII码进行对比
    = 返回 0
    > 返回 1
    < 返回 -1

③ 函数原型:


函数原型:
    int compare(const string &s) const; //与字符串s比较
    int compare(const char *s) const;   //与字符串s比较

例子

void stringtest05()
{
    string s1 = "abcdefg";
    string s2;
    s2.assign(s1);
    string s3 = "sddfghh";
    cout << "s1 : " << s1 << endl;
    cout << "s2 : " << s2 << endl;
    cout << "s3 : " << s3 << endl;

    int ret = s1.compare(s2);
    cout << "S1 & S2 比较结果 : " << ret << endl;

    ret = s1.compare(s3);
    cout << "S1 & S3 比较结果 : " << ret << endl;
}

在这里插入图片描述

2.7 string字符串存取

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

string中单个字符存取方式有两种
    char& operator[](int n);     //通过[]方式取字符
    char& at(int n);             //通过at方法获取字符

例子

void stringtest06()
{
    string s1 = "abcdefg";
    cout << "s1 = " << s1 << endl;

    for (int i = 0; i < s1.size(); i++)
    {
        cout << s1[i] << " " << endl;
    }

    char c = s1.at(3);//通过at方法获取字符
    cout << "第3个字符为: " <<c << endl;

    //通过上述两种方式修改字符串值
    s1[0] = 'x';
    cout << "s1 = " << s1 << endl;

    s1.at(3) = 'x';
    cout << "s1 = " << s1 << endl;
}

在这里插入图片描述

2.8 string字符串插入和删除

① 功能描述:对string字符串进行插入和删除字符操作。

② 函数原型:

函数原型:
    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 = npos);        //删除从Pos开始的n个字符
*/

③ 插入和删除的起始下标都是从0开始。

例子

void stringtest07()
{
    string s1 = "abcdefg";
    cout << "s1 = " << s1 << endl;

    s1.insert(2, "WWW");
    cout << "s1 = " << s1 << endl;

    s1.erase(2, 3);
    cout << "s1 = " << s1 << endl;
}

在这里插入图片描述

2.9 string子串获取

① 功能描述:从字符串中获取想要的子串。

② 函数原型:

函数原型:
    string substr(int pos = 0, int n = npos) const; //返回由pos开始的n个字符组成的字符串
*/

③ 灵活的运用求子串功能,可以在实际开发中获取有效的信息。

例子

void stringtest08()
{
    string s1 = "abcdefg";
    cout << "s1 = " << s1 << endl;

    string s2 = s1.substr(2, 3);
    cout << "s2 = " << s2 << endl;

    //截取邮箱名字
    string email = "dzl_emails@163.com";
    int pos = (int)email.find('@'); //找到 @ 符号位置
    string UserName = email.substr(0, pos);    //从位置0到pos位置间,就是邮箱名字,可以使用子串返回
    cout << "UserName : " << UserName << endl;
}

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

20240309web前端_第一周作业_古诗词

作业三&#xff1a;古诗词 成果展示&#xff1a; 完整代码&#xff1a; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0&q…

冒泡排序的理解与实现【C语言、C++、java】

冒泡排序介绍 冒泡排序(Bubble Sort)&#xff0c;又被称为气泡排序或泡沫排序。 它是一种较简单的排序算法。它会遍历若干次要排序的数列&#xff0c;每次遍历时&#xff0c;它都会从前往后依次的比较相邻两个数的大小&#xff1b;如果前者比后者大&#xff0c;则交换它们的位…

【教程】使用小米换机来迁移数据

转载请注明出处&#xff1a;小锋学长生活大爆炸[xfxuezhang.cn] 1、在新旧手机上都下载安装小米换机app&#xff1a;小米换机-小米应用商店 2、在新手机上&#xff0c;选择旧手机类型 3、授予权限 4、在旧手机上&#xff0c;授予权限 4、输入锁屏密码 5、选择发现的新手机 6、等…

后端八股笔记------Redis

Redis八股 上两种都有可能导致脏数据 所以使用两次删除缓存的技术&#xff0c;延时是因为数据库有主从问题需要更新&#xff0c;无法达到完全的强一致性&#xff0c;只能达到控制一致性。 一般放入缓存中的数据都是读多写少的数据 业务逻辑代码&#x1f447; 写锁&#x1f4…

论文笔记:Evaluating the Performance of Large Language Models on GAOKAO Benchmark

1 论文思路 采用zero-shot prompting的方式&#xff0c;将试题转化为ChatGPT的输入 对于数学题&#xff0c;将公式转化为latex输入 主观题由专业教师打分 2 数据 2010~2022年&#xff0c;一共13年间的全国A卷和全国B卷 3 结论 3.1 不同模型的zeroshot 高考总分 3.2 各科主…

Helix QAC—源码级静态自动化测试工具

Helix QAC概述 Helix QAC是一款源码级静态自动化测试工具&#xff0c;主要用于C/C代码的完全自动化静态分析工作&#xff0c;提供一个高效、健壮和自动化的环境来引入和执行编码标准。Helix QAC根据尽早、更频繁测试的理念&#xff0c;在软件生命周期最早期软件开发阶段应用识别…

03:HAL---中断

目录 一:中断 1:简历 2:AFIO 3:EXTI 4:NVIC基本结构 5:使用步骤 6:设计中断函数 二:中断的应用 A:对外式红外传感计数器 1:硬件介绍 2:计数代码 B:旋转编码计数器 1:硬件介绍 2:旋转编码器代码 C:按键控制LED D:代码总结 一:中断 1:简历 中断&#xff1a;在主程序…

数据分析-Pandas如何画图验证数据随机性

数据分析-Pandas如何画图验证数据随机性 数据分析和处理中&#xff0c;难免会遇到各种数据&#xff0c;那么数据呈现怎样的规律呢&#xff1f;不管金融数据&#xff0c;风控数据&#xff0c;营销数据等等&#xff0c;莫不如此。如何通过图示展示数据的规律&#xff1f; 数据表…

地球系统模式(CESM)

目前通用地球系统模式&#xff08;Community Earth System Model&#xff0c;CESM&#xff09;在研究地球的过去、现在和未来的气候状况中具有越来越普遍的应用。CESM由美国NCAR于2010年07月推出以来&#xff0c;一直受到气候学界的密切关注。近年升级的CESM2.0在大气、陆地、海…

ctfshow web入门 php特性总结

1.web89 intval函数的利用&#xff0c;intval函数获取变量的整数值&#xff0c;失败时返回0&#xff0c;空的数组返回&#xff0c;非空数组返回1 num[]1 intval ( mixed $var [, int $base 10 ] ) : int Note: 如果 base 是 0&#xff0c;通过检测 var 的格式来决定使用的进…

论文解读:NAND闪存中读电压和LDPC纠错码的高效设计-2

在NAND闪存中&#xff0c;理论结果表明&#xff0c;LDPC解码器的性能可通过密度进化&#xff08;Density Evolution, DE&#xff09;技术进行详尽分析。针对MLC NAND闪存&#xff0c;研究者首先建立了一个离散无记忆信道模型&#xff0c;将存储单元的阈值电压划分为七个区间&am…

前端学习之HTML 下拉框 文本框

注&#xff1a;注释是对下列代码中标签的解释 下拉框 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>下拉框</title> </head> <body><!--使用&#xff1a;select标签option标…

通信总线协议之CAN-FD协议详解

文章目录 通信总线之CAN-FD总线协议详解1. CAN-FD 简介1.1 什么是CAN FD1.2 CAN FD的特点 2. CAN-FD总线协议2.1 帧起始2.2 仲裁段2.3 控制段2.4 数据段2.5 CRC段2.6 ACK段2.7 帧结束 3. 如何从传统的CAN升级到CAN FD 通信总线之CAN-FD总线协议详解 1. CAN-FD 简介 1.1 什么是…

AJAX学习(三)

版权声明 本文章来源于B站上的某马课程&#xff0c;由本人整理&#xff0c;仅供学习交流使用。如涉及侵权问题&#xff0c;请立即与本人联系&#xff0c;本人将积极配合删除相关内容。感谢理解和支持&#xff0c;本人致力于维护原创作品的权益&#xff0c;共同营造一个尊重知识…

SpringBoot 多环境的配置(附带有截图)

文章目录 概要整体配置流程配置详细说明技术细节小结 概要 多环境开发 在实际项目开发中&#xff0c;一般需要针对不同的运行环境&#xff0c;如开发环境、测试环境、生产环境等&#xff0c;每个运行环境的数据库等配置都不相同&#xff0c;每次发布测试、更新生产都需要手动…

精酿啤酒:酿造工艺的与众不同之处与魅力

Fendi Club啤酒的酿造工艺具有与众不同之处和魅力&#xff0c;这些特点使得啤酒口感与众不同、品质卓着。 Fendi Club啤酒采用与众不同的原料配方。他们精选上好麦芽、酵母和啤酒花&#xff0c;并按照与众不同的比例进行搭配。这种与众不同的原料配方为啤酒提供了丰富的口感和…

LLM推理框架Triton Inference Server学习笔记(一): Triton Inference Server整体架构初识

官方文档查阅: TritonInferenceServer文档 1. 写在前面 这篇文章开始进行大语言模型(Large Language Model, LLM)的学习笔记整理&#xff0c;这次想从Triton Inference Server框架开始&#xff0c;因为最近工作上用到了一些大模型部署方面的知识&#xff0c; 所以就快速补充了…

记一次用Arthas排查Redis连接数增加问题(附:redis连接池优化)

手打不易&#xff0c;如果转摘&#xff0c;请注明出处&#xff01; 注明原文&#xff1a;https://zhangxiaofan.blog.csdn.net/article/details/136493572 前言 有一次生产环境发包后&#xff0c;发现redis连接数变多了&#xff0c;由于改的代码比较多&#xff0c;不确定是哪…

下载、安装并配置 Node.js

文章目录 1. 下载2. 自定义安装3. 添加环境变量4. 验证5. 修改下载位置6. npm 换源7. 测试 ➡️➡️➡️来源&#xff1a;Simplilearn.com Node.js 是一个开源、跨平台的 JavaScript 运行时环境和库&#xff0c;用于在客户端浏览器之外运行 web 应用程序。 Ryan Dahl 在2009年开…

2024.3.11 C++作业

1、提示并输入一个字符串&#xff0c;统计该字符中大写、小写字母个数、数字个数、空格个数以及其他字符个数要求使用C风格字符串完成 #include <iostream>using namespace std;int main() {char str[20];cout << "please enter the str:";gets(str);in…