c++STL容器之string容器
本质;string是c++风格的字符串,而string本质上是一个类
string和char*的区别:
- char*是一个指针;
- string是一个类,类内部封装了char*,管理这个字符串,是一个char*的容器;
特点:
string内部封装了很多内部成员方法,例如find、copy、delete、replace、insert等。
string管理char*所分配的内存,不用担心复制越界和取值越界等,由类内部进行操作。
一、string构造函数
- string():创建一个空的字符串
- string(const char* s):使用字符串s初始化
- string(const string& str):使用一个string对象初始化另一个string对象
- string(int n,char c):使用n个字符c初始化
#include<iostream>
#include<string>
using namespace std; void test() {
string s1;//默认构造
const char* str = "hello world";
string s2(str);
cout <<"s2="<< s2 << endl;
string s3(s2);
cout << "s3=" << s3 << endl;
string s4(10, 'a');
cout << "s4=" << s4 << endl;
} int main() {
test();
system("pause");
return 0;
}
二、string赋值操作
#include<iostream>
#include<string>
using namespace std; void test() {
string str1;
str1 = "hello world";
cout << "str1=" << str1 << endl;
string str2;
str2 = str1;
string str3;
str3 = 'c';
string str4;
str4.assign("hello woeld");
string str5;
str5.assign("hello world", 5);//只赋值前n个字符
string str6;
str6.assign(str5);
string str7;
str7.assign(10, 'w');//赋值十个w
} int main() {
test();
system("pause");
return 0;
}
三、字符串拼接
#include<iostream>
#include<string>
using namespace std; void test() {
string str1;
str1 = "我";
str1 += "爱中国";
cout << "str1=" << str1 << endl;
str1 += '!';
cout << "str1=" << str1 << endl;
string str2 = "LOL";
str1 += str2;
cout << "str1=" << str1 << endl;
string str3 = "i";
str3.append(" love you");
cout << "str3=" << str3 << endl;
str3.append("new gameing",4);//拼接前n个字符
str3.append(str2);
str3.append(str2, 0, 2);//只截取第0,1个字符并拼接
cout << "str3=" << str3 << endl;
} int main() {
test();
system("pause");
return 0;
}
三、字符串的查找和替换
#include<iostream>
#include<string>
using namespace std; void test() {
//1.查找
string str1 = "abcdefg";
//find、rfind只找到第一个出现的位置
cout << str1.find("bc", 0) << endl;//默认从零位置开始,并返回找到的索引位置,未找到返回-1
cout << str1.rfind("bc",6) << endl;//rfind是从右往左查找,6是起始索引位置
//2.替换
str1.replace(0, 2, "pppp");//将0-1之间的位置替换成"pppp"
cout << str1 << endl;
} int main() {
test();
system("pause");
return 0;
}
四、字符串比较
#include<iostream>
#include<string>
using namespace std; void test() {
string str1 = "hello";
string str2 = "hello";
//逐一比较每个字符的ASCII,若全部相等,返回0,若str1的ASCII大于str2则返回1,否则返回-1
str1.compare(str2);
} int main() {
test();
system("pause");
return 0;
}
五、字符串的存取
#include<iostream>
#include<string>
using namespace std; void test() {
string str1 = "hello";
//读
cout << str1[0] << endl;;
cout << str1.at(0) << endl;
//写
str1[0] = 'm';
cout << str1 << endl;
str1.at(0) = 'p';
cout << str1 << endl;
} int main() {
test();
system("pause");
return 0;
}
六、字符串的插入与删除
void test() {
string str1 = "hello";
str1.insert(1, "big");//在某个位置插入
cout << str1 << endl;
str1.erase(1, 3);//删除起始位置和最终位置之间的
cout << str1 << endl;
}
七、子串获取
void test() {
string str1 = "hello";
cout << str1.substr(1, 3) << endl;//返回1-3之间的子串,包含下标1,2,3
}
c++STL容器之string容器的更多相关文章
- [知识点]C++中STL容器之map
UPDATE(20190416):写完vector和set之后,发现不少内容全部引导到map上了……于是进行了一定的描述补充与更正. 零.STL目录 1.容器之map 2.容器之vector 3.容器 ...
- [知识点]C++中STL容器之vector
零.STL目录 1.容器之map 2.容器之vector 3.容器之set 一.前言 关于STL和STL容器的概念参见STL系列第一篇——map(见上).今天介绍第二个成员——vector. 二.用途 ...
- [知识点]C++中STL容器之set
零.STL目录 1.容器之map 2.容器之vector 3.容器之set 一.前言 继上期的vector之后,我们又迎来了另一个类数组的STL容器——set. 二.用途与特性 set,顾名思义,集合 ...
- C++STL模板库序列容器之List容器
目录 一丶List容器的存储结构 二丶丶STL中list容器的使用. 一丶List容器的存储结构 list容器底层是链表结构来维护的.跟vector不一样. vector是数组维护的.拥有连续内存.所 ...
- STL容器之map
[1]map容器 map 是关联容器.容器中的每一个元素都是由一个键值和一个数据值组成的. set 是一个集合它以其元素作为键值(同一个键值只能出现一次),且默认以升序排列. list 是一个顺序容器 ...
- STL容器之vector
[1]模板类vector 模板类vector可理解为广义数组.广义数组,即与类型无关的数组,具有与数组相同的所有操作. 那么,你或许要问:既然C++语言本身已提供了一个序列式容器array,为什么还要 ...
- STL容器之Array[转]
转自https://blog.csdn.net/sin_geek/article/details/51067874 作者 Sin_Geek 简介 array在头文件<array> 中定义 ...
- C++ STL容器之 stack
STL 中的 stack 是一种容器适配器,而不是一种容器. 它是容器适配器是指,只要支持一系列方法的容器(empty, size, back, push_back, pop_back),都能作为st ...
- STL容器之set
[1]set容器 一个集合(set)是一个容器,它其中所包含的元素的值是唯一的. [2]set容器方法 (1)set构造函数.插入函数.遍历过程 应用示例代码如下: #include <set& ...
随机推荐
- k8s 关于Job与Cronjob
在Kubernetes 中通过创建工作负载资源 Job 可完成大型计算以及一些批处理任务.比如 Job 转码文件.获取部分文件和目录,机器学习中的训练任务等.这篇小作文我们一起来了解 k8s 中关于 ...
- 395.至少有 K 个重复字符的最长子串
题目 给你一个字符串 s 和一个整数 k ,请你找出 s 中的最长子串, 要求该子串中的每一字符出现次数都不少于k .返回这一子串的长度. 示例 1: 输入:s = "aaabb" ...
- nsq - 一条消息的生命周期(一)
经过前面几篇的学习,相信大家对nsq已经有了一个大概的了解,我在写这篇文章的时候也看了很多其他人写的教程,发现大家对于分析系统每个点写的很不错,但是都很少有整体串起来一起走一遍,所以,我打算分成2-3 ...
- DevOps 时代的高效测试之路
10 月 22 日,2021 届 DevOps 国际峰会在北京顺利召开,来自国内外的顶级技术专家共同畅谈 DevOps 体系与方法.过程与实践.工具与技术.CODING 测试及研发流程管理产品总监程胜 ...
- RabbitMQ设计原理解析
背景 RabbitMQ现在用的也比较多,但是没有过去那么多啦.现在很多的流行或者常用技术或者思路都是从过去的思路中演变而来的.了解一些过去的技术,对有些人来说可能会产生众里寻他千百度的顿悟,加深对技术 ...
- 全志Tina_dolphin播放音视频裸流(h264,pcm)验证
最近在验证tina对裸流音视频的支持,主要指h264视频裸流及pcm音频裸流. 在原始sdk中有针对很多video和audio类型的parser,但就是没有找到pcm和h264的parser,所以需要 ...
- 关于iview、element-ui重置表单并清除校验的方法
平时在使用iview或者vue重置表单是时,我会习惯使用 this.$refs[formData].resetFields(); 但是直接这样写上去方法是不起作用的, 内容必须要在每个form-ite ...
- Ubuntu安装数据库
1.通过命令行安装:sudo apt-get install mysql-client mysql-server 2.安装过程中输入数据库密码("123456",root) 3.使 ...
- Downward API —— 在容器内部获取 Pod 信息
我们知道,每个 Pod 在被超过创建出来之后,都会被系统分配唯一的名字.IP地址,并且处于某个 Namespace 中,那么我们如何在 Pod 的容器内获取 Pod 的这些重要信息呢? 答案就是使用 ...
- 使用Visual Studio 2019将ASP.NET Core发布为linux-arm64程序
前言 前段时间入手了一台树莓派4B,一直闲置未使用,最近工作需要,要在上面跑下.NET Core程序,由于树莓派4B使用的是ARM架构,并且支持64位操作系统,为了充分发挥树莓派性能,我的这台树莓派安 ...