string

string

1、初识string

我们搜索string,就会发现,string其实是basic_string模板,指定类型参数为char,而实例化出来的类,再将这个类重命名为string。

而为什么要用basic_string模板来实例化出string呢?

答案是为了实例化出不同的(模板)类,用来存储不同类型的字符数据:




而我们需要不同字符类型的原因,与"编码"有关,这里我们不做深入探讨。现阶段只需好好掌握string的用法。

2、string的基本用法

2.1、构造

构造空内容:

cpp 复制代码
string s1();

拷贝构造:

cpp 复制代码
string s2(s1);

拷贝部分字符串:


拷贝部分字符串,用法上,参数列表中第一个位置为被拷贝的对象(也可以是一个常量字符串),第二个位置是拷贝的起始位置,第三个位置是要拷贝的字符个数。

当第三个位置给的值大于剩余字符个数,那么系统就会将剩余所有字符都拷贝过去。

注意到第三个位置会给一个默认值npos。npos是string类的一个静态成员变量:

npos是无符号整型的-1,这已经代表了要拷贝字符个数的最大值,保证了指定位置之后的所有内容都能被拷贝到。

传入常量字符串构造:

cpp 复制代码
string s4("Hello world!");

传入常量字符串的前n个字符构造:

传入n个字符构造:

2.2、析构

析构函数不用过多了解,因为我们使用的是编译器默认生成的构造函数和析构函数。

2.3、operator=

重载=:

  • 传入对象赋值
  • 传入常量字符串赋值
  • 传入字符赋值

2.4、遍历和修改

string对象的遍历和修改方法,可以直接用数组形式的方法:


这得益于运算符重载:operator\[\]。

operator\[\]的底层实现可能是这样的:

这样实现,有两个好处:

1、传引用返回,可以修改返回值。对比指针可不行(传值返回事先拷贝了一份,拷贝值有常性不可修改;传引用返回为对象本身,可以修改)。


2、实现为函数,可以在函数体内进行越界断言检查。对比C语言的数组越界抽查,更安全。

如果觉得断言检查太直接,可以使用at。

at在遇到越界时,会抛异常:

容器(string虽然不是容器,但是行为很像容器)中有成员函数size()、length(),都能获取元素个数。


但我们更常用size(),因为这样更好理解,比如树是由一个一个节点构成的,说length()比较奇怪。

对于修改和遍历,还有另一种方法:迭代器。

2.4.1、迭代器简单了解

迭代器,是一种行为像指针的东西。


由于我们在上面用for循环将s1的每一个字符都+1,这里演示迭代器时就将s1变回去了。

上图中使用了begin()、end()。他俩都是函数模板,返回的都是一个迭代器。

我们可以理解为:begin()指向s1的第一个字符,end()指向的是s1最后一个字符的下一个位置。

迭代器行为像指针,但是迭代器底层并不一定是完全用指针实现的。迭代器底层实现可能借助了指针。

2.4.1.1、const迭代器

迭代器作用的对象,可能是可以被修改的,也可能是不可以被修改的。所以我们就需要const迭代器。

但是这样写,就不对了。

因为迭代器是用来迭代对象,来进行对对象的遍历和修改的,也就意味着迭代器必须被修改。所以const直接作用在迭代器上是不对的。

正确写法:

使用const迭代器:const_iterator。

2.4.1.2、反向迭代器

反向迭代器和迭代器的用法很类似:

反向迭代器reverse_iterator使用了模板rbegin()、rend(),其中rbegin()对应end()的功能,rend()对应begin()的功能,所以打印出来的语句是颠倒的。

2.4.1.3、迭代器优点的简单讨论

迭代器提供了统一的方式处理各个容器,那么我们就不需要自己实现迭代的方法。

所以,C++标准库里的算法可以泛型化,算法借助了迭代器实现:

相关推荐
kyle~9 分钟前
ROS2---零拷贝
linux·c++·机器人·ros2
Ricky_Theseus12 分钟前
栈 & 队列 应用场景
数据结构·c++
薇茗13 分钟前
【C++】类与对象 核心篇
开发语言·c++
ouliten14 分钟前
C++笔记:偏现代C++日志系统
c++·笔记
猪脚饭还是好吃的15 分钟前
【分享】C4droid 安卓C++编译器 手机编程超便捷
android·c++·智能手机
草莓熊Lotso15 分钟前
【Linux网络】深入理解传输层 UDP 协议:从底层原理到实战应用
linux·运维·服务器·c语言·网络·c++·udp
小欣加油16 分钟前
leetcode542 01矩阵
数据结构·c++·算法·leetcode·矩阵·bfs
原来是猿19 分钟前
理解 C++ 哈希表的原理与工程实践
开发语言·c++·散列表
牢姐与蒯35 分钟前
c++数据结构之c++11(二)
开发语言·c++
lcj251140 分钟前
【stack、queue、deque、priority_queue】C++ 栈 / 队列 / 优先级队列全解析!手撕实现 + 二叉树层序遍历(附源码)
开发语言·c++·笔记