c++提高篇——string容器
一、string基本概念
string是C++风格的字符串,而string本质上是一个类。
与c语言不同,string是一个类,类内部封装了char*,管理这个字符串,是一个char型的容器。在根本上与c语言字符串是一致的。
在string类内部封装了很多成员方法。例如:查找find,拷贝copy,删除delete替换replace,插入insert。string管理char所分配的内存,不用担心复制越界和取值越界等,由类内部进行负责。
二、string构造函数
string();是一个默认构造,可以创建出来一个空的字符串,例如:string str;
string(const char* s);可以使用c语言的字符串来构造出一个c++的字符串
string(const string& str);是一个拷贝构造,可以使用一个string来实现另一个string对象的初始化
string(int n, char c);可以n个字符c来初始化
具体的11实现方法1如下:
//默认构造的实现string s1;//用c语言的方法构造c++风格的字符串const char * str = "hello";string s2(str);cout << "str2 = " << s2 << endl;//拷贝构造的函数实现string s3(s2);cout << "str3 = " << s3 << endl;//用n个相同的字符实现字符串string s4(10, 'd');cout << "str4 = " << s4 << endl;
三、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赋给当前字符串
具体实现方法1如下:
//方法1string str1;str1 = "hello";cout << "str1 = " << str1 << endl;//方法2string str2;str2 = str1;cout << "str2 = " << str2 << endl;//方法3string str3;str3 = "a";cout << "str3 = " << str3 << endl;//方法4string str4;str4.assign("hello");cout << "str4 = " << str4 << endl;//方法5string str5;str5.assign("hello", 3);cout << "str5 = " << str5 << endl;//方法6string str6;str6.assign(str5);cout << "str6 = " << str6 << endl;//方法7string str7;str7.assign(2, 'a');cout << "str7 = " << str7 << endl;
四、字符串的拼接
拼接方法如下:
string& operator+=(const char* str); 重载+=操作符
string& operator+=( const char c);重载+=操作符
string& operator+=( const string& str);重载+=操作符
string& append(const char ”s);把字符串s连接到当前字符串结尾
string8 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个字符连接到字符串结尾
具体的实现细节如下:
//方法1string str1 = "来";str1 += "玩呀";cout << "str1 = " << str1 << endl;//方法2str1 += "~";cout << "str1 = " << str1 << endl;//方法3string str2 = "!";str1 += str2;cout << "str1 = " << str1 << endl;//方法4string str3 = "we ";str3.append("are ");cout << "str3 = " << str3 << endl;//方法5str3.append("friend 1212", 6);cout << "str3 = " << str3 << endl;//方法6str3.append(str2);cout << "str3 = " << str3 << endl;//方法7string str4 = "123456";str3.append(str4, 1, 2);cout << "str3 = " << str3 << endl;
以上的输出结果为:
str1 = 来玩呀
str1 = 来玩呀~
str1 = 来玩呀~!
str3 = we are
str3 = we are friend
str3 = we are friend!
str3 = we are friend!23
五、string查找和替换
查找:查找指定字符串是否存在
替换:在指定的位置1替换字符串
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
部分样例如下:
string str1 = "abcdfghigab";//从前往后查int pos = str1.find("abc");if (pos == -1){cout << "未找到" << endl;}else{cout << "方法1:= " << pos << endl;}//从后往前查int pos1 = str1.rfind("ab");if (pos1 == -1){cout << "未找到" << endl;}else{cout << "方法2:= " << pos1 << endl;}
string str1 = "abcdfghigab";//从1号位置起3个字符替换为1111str1.replace(1, 3, "1111");cout << "str1: " << str1;
六、string字符串比较
在字符串比较中是按字符的ASCII码进行对比的:
当=时返回0、>返回 1、<返回-1
基本语法如下:
int compare(const string &s const;与字符串s比较
int compare( const char *s) const与字符串s比较
具体的样例如下
string str1 = "HelLo";string str2 = "hello";int a = str1.compare(str2);cout << a << endl;
此时输出的a为-1,以此类推即可。
七、string字符的存取
string中单个字符存取方式有两种:
1、char& operator[ ](int n);通过[]方式取字符
char& at(int n);通过at方法获取字符
具体实现样例如下:
string str = "hello";cout << str << endl;//1、通过[]访问单个字符串for (int i = 0; i < str.size(); i++){cout << str[i] << " ";}cout << endl;//2、通过at方式访问for (int i = 0; i < str.size(); i++){cout << str.at(i) << " ";}cout << endl;//3、修改单个字符str[0] = 'a';cout << str << endl;str.at(0) = 'c';cout << str << endl;
八、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个字符
具体实现样例如下:
string str = "hello";//插入字符串str.insert(1, "e");cout << str << endl;//删除字符串str.erase(1, 3);cout << str << endl;
九、string子串
从字符串中获取想要的子串
语法如下:
string substr(int pos = 0 ,int n = npos) const; 返回由pos开始的n个字符组成的字符串
具体的实现如下:
string str = "hello";string sub = str.substr(1, 2);cout << sub << endl;
十、实用小语法
截取邮箱的用户名
string str = "zhangsan@email.com"//从邮件中查找标志符@
int pos = str.find("@");
//截取用户名
string UsrName = str.substr(0, pos);
相关文章:
c++提高篇——string容器
一、string基本概念 string是C风格的字符串,而string本质上是一个类。 与c语言不同,string是一个类,类内部封装了char*,管理这个字符串,是一个char型的容器。在根本上与c语言字符串是一致的。 在string类内部封装了很…...
[软件工程导论(第六版)]第6章 详细设计(复习笔记)
文章目录6.1 结构程序设计6.2 人机界面设计6.3 过程设计的工具6.3.1 程序流程图(程序框图)6.3.2 盒图(N-S图)6.3.3 PAD图(问题分析图)6.3.4 判定表6.3.5 判断树6.3.6 过程设计语言6.4 面向数据结构的设计方…...
RabbitMQ核心内容:实战教程(java)
文章目录一、安装二、入门1.分类2.核心概念3.工作原理4.六大模式三、模式一:"Hello World!"1.依赖2.生产者代码3.消费者代码四、模式二:Work Queues1.工作原理2.工具类代码:连接工厂3.消费者代码4.生产者代码5.分发策略不公平分发预…...
RK356x U-Boot研究所(命令篇)3.7 pci与nvme命令的用法
平台U-Boot 版本Linux SDK 版本RK356x2017.09v1.2.3文章目录 一、设备树与config配置二、pci命令的定义三、nvme命令的定义四、pci与nvme命令的用法3.1 pci总线扫描3.2 nvme设备信息3.3 nvme设备读写一、设备树与config配置 RK3568支持PCIe接口,例如ROC-RK3568-PC: 原理图如…...
微信头像昵称获取能力的变化导致了我半年没更新小程序
背景 2022年9月份,微信更改了获取头像昵称的规则,回收了原有 wx.getUserProfile 中的部分能力,为了减小对【微点记账】小程序的影响,长达半年未做任何更新,今天为了增加这个聊天机器人的功能,不得不重新查…...
【深度学习编译器系列】1. 为什么需要深度学习编译器?
本系列是自学深度学习编译器过程中的一些笔记和总结,参考文献在文末。 1. 概述 深度学习(DL)编译器的产生有两方面的因素:深度学习模型的广泛应用,以及深度学习芯片的层出不穷。 一方面,我们现在有非常多…...
数据结构与算法总结整理(超级全的哦!)
数据结构与算法基础大O表示法时间复杂度大O表示法时间复杂度排序:最坏时间复杂度时间复杂度的几条基本计算规则内存工作原理什么是内存内存主要分为三种存储器随机存储器(RAM)只读存储器(ROM)高速缓存(Cach…...
DPDK — MALLOC 堆内存管理组件
目录 文章目录 目录MALLOC 堆内存管理组件rte_malloc() 接口malloc_heap 结构体malloc_elem 结构体内存初始化流程内存申请流程内存释放流程MALLOC 堆内存管理组件 MALLOC(堆内存管理组件)基于 hugetlbfs 内核文件系统来实现,能够从 HugePage 中分配一块连续的物理大页内存…...
分享113个HTML艺术时尚模板,总有一款适合您
分享113个HTML艺术时尚模板,总有一款适合您 113个HTML艺术时尚模板下载链接:https://pan.baidu.com/s/1ReoPNIRjkYov-SjsPo0vhg?pwdjk4a 提取码:jk4a Python采集代码下载链接:采集代码.zip - 蓝奏云 女性化妆用品网页模板 粉…...
2023年美赛C题Wordle预测问题一建模及Python代码详细讲解
相关链接 (1)2023年美赛C题Wordle预测问题一建模及Python代码详细讲解 (2)2023年美赛C题Wordle预测问题二建模及Python代码详细讲解 (3)2023年美赛C题Wordle预测问题三、四建模及Python代码详细讲解 &…...
小米12s ultra,索尼xperia1 iv,数码相机 拍照对比
首先说明所有的测试结果和拍摄数据我放到百度网盘了(地址在结尾) 为什么做这个测试 我一直想知道现在的手机和相机差距有多大,到底差在哪儿? 先说结论: 1.1英寸的手机cmos(2022年) 6年前(2016)的入门款相机(m43画幅) 2.手机 不能换镜头,只能在特定的拍摄距离才能发挥出全…...
C++笔记 模板的进阶知识
目录 1. 非类型模板参数 2.模板的特化 2.1 函数模板的特化 2.2 类模板的特化 2.2.1 全特化 2.2.2 偏特化 3.模板的分离编译 3.1 什么是分离编译? 3.2 模板的分离编译 4.模板的总结 模板的初阶内容:(594条消息) C模板的原理和使用_全貌的博客-CSD…...
基于 Debain11 构建 asp.net core 6.x 的基础运行时镜像
基于 Debain11 构建 asp.net core 6.x 的基础运行时镜像Linux 环境说明Debian 简介Debian 发行版本关于 Debian 11Linux 常用基础工具Dockerfile 中 RUN 指令RUN 语法格式RUN 语义说明编写 Dockerfile 构建 Runtime 基础镜像ASP.NET Core Runtime 基础镜像Dockerfile 编写Windo…...
【无人机路径规划】基于IRM和RRTstar进行无人机路径规划(Matlab代码实现)
💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…...
Spring Boot中使用@Autowire装配接口是怎么回事?
在学习使用Spring Boot框架时候,发现了一个特别的现象UserMapper是一个接口,在另一个类中好像直接使用Autowired装配了一个UserMapper对象???我纳闷了一会儿,接口居然可以直接实例对象吗?根据我…...
23种设计模式介绍(Python示例讲解)
文章目录一、概述二、设计模式七种原则三、设计模式示例讲解1)创建型模式1、工厂模式(Factory Method)【1】简单工厂模式(不属于GOF设计模式之一)【2】工厂方法模式2、抽象工厂模式(AbstractFactory&#x…...
初识Hadoop,走进大数据世界
文章目录数据!数据!遇到的问题Hadoop的出现相较于其他系统的优势关系型数据库网格计算本文章属于Hadoop系列文章,分享Hadoop相关知识。后续文章中会继续分享Hadoop的组件、MapReduce、HDFS、Hbase、Flume、Pig、Spark、Hadoop集群管理系统以及…...
加油站会员管理小程序实战开发教程14 会员充值
我们上篇介绍了会员开卡的业务,开卡是为了创建会员卡的信息。有了会员卡信息后我们就可以给会员进行充值。当然了充值这个业务是由会员自主发起的。 按照我们的产品原型,我们在我的页面以轮播图的形式循环展示当前会员的所有卡信息。这个会员卡信息需要先用变量从数据源读取…...
leetcode 1792. 最大平均通过率
一所学校里有一些班级,每个班级里有一些学生,现在每个班都会进行一场期末考试。给你一个二维数组 classes ,其中 classes[i] [passi, totali] ,表示你提前知道了第 i 个班级总共有 totali 个学生,其中只有 passi 个学…...
15-基础加强-2-xml(约束)枚举注解
文章目录1.xml1.1概述【理解】(不用看)1.2标签的规则【应用】1.3语法规则【应用】1.4xml解析【应用】1.5DTD约束【理解】1.5.1 引入DTD约束的三种方法1.5.2 DTD语法(会阅读,然后根据约束来写)1.6 schema约束【理解】1.6.1 编写schema约束1.6.…...
JVM垃圾回收机制全解析
Java虚拟机(JVM)中的垃圾收集器(Garbage Collector,简称GC)是用于自动管理内存的机制。它负责识别和清除不再被程序使用的对象,从而释放内存空间,避免内存泄漏和内存溢出等问题。垃圾收集器在Ja…...
让AI看见世界:MCP协议与服务器的工作原理
让AI看见世界:MCP协议与服务器的工作原理 MCP(Model Context Protocol)是一种创新的通信协议,旨在让大型语言模型能够安全、高效地与外部资源进行交互。在AI技术快速发展的今天,MCP正成为连接AI与现实世界的重要桥梁。…...
k8s业务程序联调工具-KtConnect
概述 原理 工具作用是建立了一个从本地到集群的单向VPN,根据VPN原理,打通两个内网必然需要借助一个公共中继节点,ktconnect工具巧妙的利用k8s原生的portforward能力,简化了建立连接的过程,apiserver间接起到了中继节…...
优选算法第十二讲:队列 + 宽搜 优先级队列
优选算法第十二讲:队列 宽搜 && 优先级队列 1.N叉树的层序遍历2.二叉树的锯齿型层序遍历3.二叉树最大宽度4.在每个树行中找最大值5.优先级队列 -- 最后一块石头的重量6.数据流中的第K大元素7.前K个高频单词8.数据流的中位数 1.N叉树的层序遍历 2.二叉树的锯…...
有限自动机到正规文法转换器v1.0
1 项目简介 这是一个功能强大的有限自动机(Finite Automaton, FA)到正规文法(Regular Grammar)转换器,它配备了一个直观且完整的图形用户界面,使用户能够轻松地进行操作和观察。该程序基于编译原理中的经典…...
Xen Server服务器释放磁盘空间
disk.sh #!/bin/bashcd /run/sr-mount/e54f0646-ae11-0457-b64f-eba4673b824c # 全部虚拟机物理磁盘文件存储 a$(ls -l | awk {print $NF} | cut -d. -f1) # 使用中的虚拟机物理磁盘文件 b$(xe vm-disk-list --multiple | grep uuid | awk {print $NF})printf "%s\n"…...
基于 TAPD 进行项目管理
起因 自己写了个小工具,仓库用的Github。之前在用markdown进行需求管理,现在随着功能的增加,感觉有点难以管理了,所以用TAPD这个工具进行需求、Bug管理。 操作流程 注册 TAPD,需要提供一个企业名新建一个项目&#…...
使用LangGraph和LangSmith构建多智能体人工智能系统
现在,通过组合几个较小的子智能体来创建一个强大的人工智能智能体正成为一种趋势。但这也带来了一些挑战,比如减少幻觉、管理对话流程、在测试期间留意智能体的工作方式、允许人工介入以及评估其性能。你需要进行大量的反复试验。 在这篇博客〔原作者&a…...
tomcat入门
1 tomcat 是什么 apache开发的web服务器可以为java web程序提供运行环境tomcat是一款高效,稳定,易于使用的web服务器tomcathttp服务器Servlet服务器 2 tomcat 目录介绍 -bin #存放tomcat的脚本 -conf #存放tomcat的配置文件 ---catalina.policy #to…...
自然语言处理——文本分类
文本分类 传统机器学习方法文本表示向量空间模型 特征选择文档频率互信息信息增益(IG) 分类器设计贝叶斯理论:线性判别函数 文本分类性能评估P-R曲线ROC曲线 将文本文档或句子分类为预定义的类或类别, 有单标签多类别文本分类和多…...
