vector详解

迭代器

vector维护的是一个连续线性空间。普通指针可以满足条件作为vector的迭代器。

template <typename T, typename Alloc=alloc>

class vector

{

public:

using value_type = T;

using iterator = value_type*;

};

vector::iterator //int*

vector::iterator //char*

数据存储

迭代器start和finish分别表示vector的起始元素的地址和终止元素的地址。

end_of_storage 表示vector开辟的空间的终止位置。

start - finish 表示的就是我们在连续空间中已经使用的范围。

start - end_of_storage 表示我们的总的空间大小。

finish - end_of_storage 表示我们还未使用过的空间总大小。

数据填充

无需扩容的情况:并且到finish为止,现有的元素的数量(elem_after)大于等于插入的元素数量 n

首先把绿色区域往后拷贝

把蓝色区域往后拷贝

最后在position位置拷贝进新的元素

无需扩容的情况:但是到finish为止,现有的元素的数量(elem_after)小于插入的元素数量 n

直接把n 大于elem_after之后的部分拷贝到 finish之后

把position到finish之间原有的元素全部拷贝到finish之后,为图中蓝色区域,

最后把剩余的n的一部分填充至 position到finish之间,使用 fill填充

需要扩容的情况:剩余备用的元素无法存放进全部的 n 个元素,因此需要重新分配空间,并且销毁原空间。获得容纳全部元素至少需要多少空间,重新分配空间,首地址发生改变。

首先把start到position的全部元素拷贝到新的空间

新入的n个元素翻入finish之后

最后再把原来 position到 finish之间的元素全部拷贝到 finish之后

最后调整新的 start finish end_storage

相关推荐
十年编程老舅7 小时前
窥探内核心脏:深入解析 proc 虚拟文件系统
linux·服务器·数据库·c++·linux内核·文件系统·读写锁
xiaoye-duck7 小时前
【C++:哈希表】从哈希冲突到负载因子:深入探索开放定址与链地址法的核心机密
数据结构·c++·散列表
小辉同志7 小时前
739. 每日温度
c++·算法·leetcode
羊小猪~~8 小时前
Redis学习笔记(数据类型、持久化、事件、管道、发布订阅等)
开发语言·数据库·c++·redis·后端·学习·缓存
小菜鸡桃蛋狗9 小时前
C++——模板
c++
程序喵大人9 小时前
C++依赖关系分析:5个工具理清模块关系
开发语言·c++
charlie1145141919 小时前
嵌入式C++教程实战之Linux下的单片机编程:从零搭建 STM32 开发工具链(3)WSL2 USB 透传,让 ST-Link 穿越虚拟化边界
c++·stm32·单片机·学习·嵌入式
AIminminHu9 小时前
OpenGL渲染与几何内核那点事-项目实践理论补充(一-2-(2)-当你的CAD需要处理“百万个螺栓”时:从内存爆炸到丝般顺滑)
c++·cad
小李小李快乐不已9 小时前
docker(1)-环境和基本概念
运维·c++·docker·容器
海参崴-9 小时前
C++ 位运算从入门到精通(全知识点+面试题+实战应用)
开发语言·c++