C++中的string的介绍
文章目录
- C++中的string的介绍
 - 1. 从string到STL
 - 2. string 的构造函数
 - 3. string 的iterator(迭代器)
 - 4. string 中的元素访问
 - 5. string 中容量相关
 - 6. string 中的插入删除
 - 7. string 中的查找
 - 8. string 的剩余函数
 
1. 从string到STL
严格来说string不是Containers 容器,也就不属于STL C++ 标准模板库,因为string是早于STL的,所以没有作业可以抄,导致string中有很多,约100多个,有很多功能是相似的,所以只介绍一些常用的函数,虽然Containers 容器 中有很多不同类模板,但函数命名以及函数的形参是类似的,读懂一个类模板就基本明白了
string本质上就是一个存储char类型的顺序表
类似:
- char* _ptr
 - size_t _size
 - size_t _capacity
 
2. string 的构造函数

-  
(1) string的默认构造(用户不写由编译器自动生成的),生成空字符串
string s; -  
(2)string的拷贝构造,用另一个string拷贝构造
string s1(s2); -  
(3) 用string pos位置开始,向后 len个长度的部分,拷贝构造string
pos为缺省参数,不写则为 0
len为缺省参数,不写则为npos是string的成员常量,为size_t npos = -1,也就是整型的最大值
string s1(s2,0,10); -  
(4) 用一个字符串构造
string s("hello world"); -  
(5) 用一个字符串的前N个构造
string s("hello world",5); -  
(6) 用N个c构造
string s(5,'x'); -  
(7) 用迭代区间构造(下面会提到)
 
3. string 的iterator(迭代器)

   迭代器是C++标准模板库(STL)中的一个核心概念,用来遍历容器中的元素,类似于指针,可以说指针是一种迭代器,但不能说迭代器是指针,因为你不知道迭代器的底层是什么
VS2022 x86下的迭代器类型
-  
begin 返回指向第一个元素的迭代器,提供了const和非const两个版本(其他的也一样)

 -  
end返回指向最后一个元素的下一个位置的迭代器
 -  
rbegin是逆序迭代器,返回指向最后一个元素的下一个位置
 -  
end返回指向第一个元素的迭代器
 
4. string 中的元素访问

- operator[]是通过像数组一样,用下标的方式来访问
s[5]; - at类似于operator[],只不过at会进行边界的强制检查,越界则会抛出异常,而operator[]不会对边界进行检查
s.at(5); - back 和front返回最后/第一个元素的引用
s.back() / s.front(); 
遍历string的三种方法
-  
  
- operator[] 通过下标来访问数据
 
 
string s("hello wolrd");
for (int i = 0; i < s.size(); ++i)\
{
	cout << s[i] << " ";
}
cout << endl;
 
-  
  
- iterator 通过迭代器来访问 迭代器需配对使用,正序对正序,逆序对逆序
 
 
string s("hello wolrd");
//正序打印
string::iterator it = s.begin();
while (it != s.end())
{
	cout << *it << " ";
	++it;
}
cout << endl;
//逆序打印
string::reverse_iterator it = s.rbegin();
while (it != s.rend())
{
	cout << *it << " ";
	++it;
}
cout << endl;
//const的string打印
const string s("hello wolrd");
string::const_iterator it = s.begin();
while (it != s.end())
{
	cout << *it << " ";
	++it;
}
cout << endl;
 
-  
  
- 范围for 通过自动判断开始和结束,以及自动++
 
 
	string s("hello wolrd");
	for (auto ch : s)
	{
		cout << ch << " ";
	}
	cout << endl;
 
5. string 中容量相关

-  
size length 返回string的字符个数,length 是只针对string ,而size 是所有容器都有的成员函数
 -  
max_size 返回最大能容纳的长度
 -  
capacity 返回string 的容量
 -  
clear 清空string
 -  
empty 判断string是否为空
 -  
shrink_to_fit将string缩小至合适的容量,避免空间浪费
 -  
resize 调整string 的大小,会删除多余的元素
 -  
reserve 调整string 的容量,一般情况下,如果调整的容量要小于原本的容量,编译器不会进行缩容的
 
	string str("Hello World.");
	str.reserve(111);//扩容至111
	str.resize(5);  //调整元素个数为5,删除多余元素
	str.reserve(50); //不改变大小
 
6. string 中的插入删除

-  
operator+= 在结尾添加一个string/一个字符串/一个字符

 -  
append 在结尾追加一个string/string的一部分/一个C字符串/一个C字符串的前N个/N个c字符/一个迭代区间

 -  
push_back 尾插一个字符
 -  
insert 从pos位置开始插入一个string/从pos位置开始插入一个string的一部分/从pos位置开始插入一个C字符串/从pos位置开始插入一个C字符串的前N个/从pos位置开始插入N个c字符/从迭代器位置开始插入N个c字符/从迭代器位置开始插入一个字符/从迭代器位置开始插入一段迭代区间

 -  
assign用一个string的值修改原string/用string的一部分来修改原string/用一个C字符串来修改原string/用一个C字符串的前N个来修改原string/用N个c字符来修改原string/用一个迭代区间的值来修改原string

 -  
erase默认全删除(或者传一段范围,如果len大于pos之后的长度则删除pos之后的全部字符)/删除一个迭代器指向的字符/删除一段迭代区间的字符

 -  
swap 交换两个string
 -  
pop_back尾删一个字符operator+=
 
可以看到在string中有许多重复功能的函数,例如push_back append 和operator+=,都使用operator+=来尾插字符不是更好嘛,所以string在设计上有很多重复的地方,只需要了解常见的函数即可
7. string 中的查找

-  
c_str 返回字符串首元素的地址
 -  
find 查找第一个符合要求下标
str.find("hello")//找到单词hello -  
rfind 逆序查找第一个符合要求下标
 -  
find_first_of find_last_of查找任意一个符合要求的下标(可以有多个要求)
str.find_first_of("aeiou")//找到a e i o u任意一个第一次出现的下标 -  
find_first_of find_last_of查找任意一个不符合要求的下标
 -  
substr 生成子串(从pos向后len个字符,并返回这部分string)
 
8. string 的剩余函数

- operator>> operator<< 允许string像内置类型一样输入输出
 

- operator= 是string的赋值重载,类似与assign的功能,将新的值赋值给string
 




















