5 STL-string
重新系统学习c++语言,并将学习过程中的知识在这里抄录、总结、沉淀。同时希望对刷到的朋友有所帮助,一起加油哦!
生命就像一朵花,要拼尽全力绽放!死磕自个儿,身心愉悦!
写在前面,本篇章主要介绍STL中常用容器string。
1.1 string的基本概念
本质:
string是c++风格的字符串,本质上是一个类。
string和char*的区别:
- char*是一个指针
- string是一个类,类内部封装了char*,管理这个字符串是一个char*型的容器。
特点:
(1) string类内部封装了很多成员方法:
——查找find、拷贝copy、删除delete、替换replace、插入insert
(2) string管理了char*所分配的内存,不用担心复制或取值越界等问题,由类内部进行负责。
1.2 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>
#include <string>
using namespace std;
// string的构造函数
// string(); 创建一个空字符串,例如:string str;
// string(const char* s); 使用字符串s初始化
// string(const string& str) 使用一个string对象初始化另一个string对象
// string(int n,char c) 使用n个字符c初始化string
void test() {
string s;
const char* str = "sdfd";
string s1(str);
cout << "s1 = " << s1 << endl;
string s2(s1);
cout << "s2 = " << s2 << endl;
string s3(5, 'x');
cout << "s3 = " << s3 << endl;
}
int main() {
test();
system("pause");
return 0;
}

1.3 string赋值操作
作用:
给string进行赋值
赋值函数原型:
- string& operator=(const char* s); char*类型字符串 赋值给当前string
- string& operator=(const string& s); string类型s 赋值给当前string
- string& operator=(char c); 字符 赋值给当前string
- string& assign(const char* s); 字符串s 赋值给当前string
- string& assign(const char* s, int n); 字符串s的前n个字符 赋值给当前string
- string& assign(const string& s); 字符串s 赋值给当前string
- string& assign(int n, char c); 用n个字符c 赋值给当前string
示例:
#include <iostream>
#include <string>
using namespace std;
//string赋值操作
//string& operator=(const char* s); char*类型字符串 赋值给当前string
//string& operator=(const string& s); string类型s 赋值给当前string
//string& operator=(char c); 字符 赋值给当前string
//string& assign(const char* s); 字符串s 赋值给当前string
//string& assign(const char* s, int n); 字符串s的前n个字符 赋值给当前string
//string& assign(const string& s); 字符串s 赋值给当前string
//string& assign(int n, char c); 用n个字符c 赋值给当前string
void test() {
string s1;
s1 = "hello";
cout <<"s1 = "<< s1 << endl;
string s2;
s2 = s1;
cout << "s2 = " << s2 << endl;
string s3;
s3 = 'a';
cout << "s3 = " << s3 << endl;
string s4;
s4.assign("hi");
cout << "s4 = " << s4 << endl;
string s5;
s5.assign("teststring", 4);
cout << "s5 = " << s5 << endl;
string s6;
s6.assign(s5);
cout << "s6 = " << s6 << endl;
string s7;
s7.assign(5, 'c');
cout << "s7 = " << s7 << endl;
}
int main() {
test();
system("pause");
return 0;
}

1.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个字符连接到当前字符串结尾
示例:
#include <iostream>
#include <string>
using namespace std;
//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 test() {
string s1("hello");
s1 += " echo";
cout << "s1 = " << s1 << endl;
string s2;
s2 += 'x';
cout << "s2 = " << s2 << endl;
string s3="say ";
s3 += s1;
cout << "s3 = " << s3 << endl;
string s4 = s3;
s4.append(" aaa");
cout << "s4 = " << s4 << endl;
string s5 = s3;
s5.append(" 12345",3);
cout << "s5 = " << s5 << endl;
string s6 = s3;
s6.append(s2);
cout << "s6 = " << s6 << endl;
string s7 = s3;
s7.append(" 12345", 1,3);
cout << "s7 = " << s7 << endl;
}
int main() {
test();
system("pause");
return 0;
}

1.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第一次出现位置,从pos开始查找
- 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和rfind都返回查找到的字符串所在的第一个字符位置,找不到返回-1;
- replace在替换时,要指定原串被替换的起始位置,被替换字符个数,用什么字符串来替换。
示例:
#include <iostream>
#include <string>
using namespace std;
//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第一次出现位置,从pos开始查找
//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
// 查找
void test() {
string s1 = "abcdefgde";
int pos = s1.find("de");
if (pos == -1) {
cout << "not find" << endl;
}
else {
cout << "pos = " << pos << endl;
}
// find和rfind的区别:
// find从左往右找,rfind从右往左找
pos =s1. rfind("de");
cout << "pos = " << pos << endl;
}
// 替换
void test2() {
string s1 = "abcdefg";
// 从位置1起 3 个字符替换为 1234
s1.replace(1, 3, "1234");
cout << "s1 = " << s1 << endl;
s1 = "abcdefg";
// 从位置1起 3 个字符替换为 12
s1.replace(1, 3, "12");
cout << "s1 = " << s1 << endl;
}
int main() {
//test();
test2();
system("pause");
return 0;
}

1.6 string字符串比较
作用:
字符串之间大小比较
比较方式:
字符串比较是按照字符的ASCII码进行比较的。
= 返回 0
> 返回 1
< 返回 -1
函数原型:
- int compare(const string& s) const; 字符串与字符串比较
- int compare(const char* s) const; 字符串与字符串比较
注意:
字符串比较一般用于比较两个字符串是否相等。
示例:
#include <iostream>
#include <string>
using namespace std;
void test() {
string s1 = "hello";
string s2 = "hello";
int ret = s1.compare(s2);
if (ret == 0) {
cout << "s1 等于 s2" << endl;
}
else if (ret > 0) {
cout << "s1 大于 s2" << endl;
}
else {
cout << "s1 小于 s2" << endl;
}
}
int main() {
test();
system("pause");
return 0;
}

1.7 string字符存取
string中单个字符存取方式有两种:
- char& operator[](int n); 通过[]数组下标形式取字符
- char& at(int n); 通过at方法获取字符
示例:
#include <iostream>
#include <string>
using namespace std;
void test() {
string s = "abcdefg";
// 获取单个字符
cout << s[1] << endl;
cout << s.at(1) << endl;
// 修改单个字符
s[1] = 'x';
cout << s << endl;
s.at(1) = 'y';
cout << s << endl;
}
int main() {
test();
system("pause");
return 0;
}

1.8 string插入和删除
作用:
对string字符串进行插入和删除字符操作
函数原型:
- string& insert(int pos, const char* s); //在指定位置n处,插入字符串
- string& insert(int pos, const string& str); //在指定位置n处,插入字符串
- string& insert(int pos, int n, char c); //在指定位置插入n个字符c
- string& erase(int pos = 0, int n = npos); //删除从Pos开始的n个字符
示例:
#include <iostream>
#include <string>
using namespace std;
//string& insert(int pos, const char* s); //在指定位置n处,插入字符串
//string& insert(int pos, const string& str); //在指定位置n处,插入字符串
//string& insert(int pos, int n, char c); //在指定位置插入n个字符c
//string& erase(int pos, int n = npos); //删除从Pos开始的n个字符
void test() {
// 插入
string s = "abc";
s.insert(1, "123");
cout << "s = " << s << endl;
s.insert(2, 3,'x');
cout << "s = " << s << endl;
// 删除
s.erase(2, 3);
cout << "s = " << s << endl;
}
int main() {
test();
system("pause");
return 0;
}

1.9 string子串
作用:
从字符串中获取想要的子串
函数原型:
string substr(int pos =0 ,int n=npos) const; 返回由pos开始的n个字符组成的字符串
示例:
#include <iostream>
#include <string>
using namespace std;
void test() {
string s = "abcdefg";
cout << s.substr(1, 3) << endl;
}
void test2() {
string email = "tom@163.com";
int pos = email.find("@");
string userName = email.substr(0, pos);
cout << userName << endl;
}
int main() {
test();
test2();
system("pause");
return 0;
}

5 STL-string的更多相关文章
- 深入剖析 linux GCC 4.4 的 STL string
转自: 深入剖析 linux GCC 4.4 的 STL string 本文通过研究STL源码来剖析C++中标准模板块库std::string运行机理,重点研究了其中的引用计数和Copy-On-Wri ...
- 格式字符串分配stl::string
代码非常easy,不解释,直接在代码: #include <cstdio> #include <cstdarg> #include <iostream> using ...
- 浅谈C++ STL string容器
浅谈C++ STL string容器 本篇随笔简单讲解一下\(C++STL\)中\(string\)容器的使用方法及技巧. string容器的概念 其实\(string\)并不是\(STL\)的一种容 ...
- C++标准模板库Stand Template Library(STL)简介与STL string类
参考<21天学通C++>第15和16章节,在对宏和模板学习之后,开启对C++实现的标准模板类STL进行简介,同时介绍简单的string类.虽然前面对于vector.deque.list等进 ...
- 转C++之stl::string写时拷贝导致的问题
前几天在开发某些数据结构到文件的 Dump 和 Load 功能的时候, 遇到的一个 bug . [问题复现] 问题主要出在 Load 过程中,从文件读取数据的时候, 直接使用 fread 的去操作 s ...
- [转载] C++ STL string的Copy-On-Write技术
原文: http://coolshell.cn/articles/12199.html stl的string是经过严格优化的, 深入理解对以后编程过程中应用string非常有益处, 感谢左耳朵耗子的精 ...
- stl string
10.2.1 STL的string 1String概念 ² string是STL的字符串类型,通常用来表示字符串.而在使用string之前,字符串通常是用char*表示的.string与char*都 ...
- [转] 深入剖析 linux GCC 4.4 的 STL string
本文通过研究STL源码来剖析C++中标准模板块库std::string运行机理,重点研究了其中的引用计数和Copy-On-Write技术. 平台:x86_64-redhat-linux gcc ver ...
- STL - string(典型操作demo)
1String概念 string是STL的字符串类型,通常用来表示字符串.而在使用string之前,字符串通常是用char*表示的.string与char*都可以用来表示字符串,那么二者有什么区别呢 ...
- STL——string
C++之string类型详解 之所以抛弃char*的字符串而选用C++标准程序库中的string类,是因为他和前者比较起来,不必担心内存是否足够.字符串长度等等,而且作为一个泛型类出现,他集成的操作函 ...
随机推荐
- Gitea 1.17.1 正式发布 | 08 累积更新
Gitea 1.17.1 已正式发布.在这个小的版本更新中我们合并了 35 个 PR,没有包含功能性的更改,但我们强烈建议用户升级到此版本以获得重要的修复补丁. 致谢:感谢报告问题的安全研究人员,同时 ...
- Python数据科学手册-Numpy数组的计算:比较、掩码和布尔逻辑,花哨的索引
Numpy的通用函数可以用来替代循环, 快速实现数组的逐元素的 运算 同样,使用其他通用函数实现数组的逐元素的 比较 < > 这些运算结果 是一个布尔数据类型的数组. 有6种标准的比较操作 ...
- 怎样编写正确、高效的 Dockerfile
基础镜像 FROM 基础镜像 基础镜像的选择非常关键: 如果关注的是镜像的安全和大小,那么一般会选择 Alpine: 如果关注的是应用的运行稳定性,那么可能会选择 Ubuntu.Debian.Cent ...
- 如何修改 Kubernetes 节点 IP 地址
转载自:https://www.qikqiak.com/post/how-to-change-k8s-node-ip/ 昨天网络环境出了点问题,本地的虚拟机搭建的 Kubernetes 环境没有固定 ...
- 【前端必会】NVM,管理你的node版本
介绍 用nvm管理node,可以随时修改node版本 使用 下载nvm https://github.com/coreybutler/nvm-windows/releases/tag/1.1.9 安装 ...
- 线程池底层原理详解与源码分析(补充部分---ScheduledThreadPoolExecutor类分析)
[1]前言 本篇幅是对 线程池底层原理详解与源码分析 的补充,默认你已经看完了上一篇对ThreadPoolExecutor类有了足够的了解. [2]ScheduledThreadPoolExecut ...
- 改善C#程序的方法-1 操作字符串
正确操作字符串 引言: 字符串是使用很频繁的一种数据类型. 如果使用不慎,则会为一次字符串操作所带来的额外性能开销而付出代价. 下面从这几个方面来探讨如何正确操作字符串: 1.确保尽量少的装箱,尽可能 ...
- Java程序设计(四)作业
要求:定义一个Java项目,项目名为"学号_姓名_题号",如:"20181101_张三_1",完成后将项目复制到桌面并压缩提交到邮箱82794085@qq.co ...
- 基于AIE的贵州省FVC提取
植被覆盖度获取 植被覆盖度(Fractional Vegetation Cover,FVC),是指植被(包括叶.茎.枝)在地面的垂直投影面积占统计区总面积的百分比,范围在 [0,1] 之间.FVC 是 ...
- uoj348【WC2018】州区划分
题目链接 直接讲吨吨吨给的标准做法吧.记\(f(i,j)\)表示各个州(可以重叠)的城市数量之和为i,这些州的并集为j的方案数,反正若有两个州之间有交集最后的\(|j|\)会不等于\(i\).有 \( ...