vector模拟实现

首先先看一个列题,杨辉三角

好,那么接下来直接看vector的底层

这里我们用模板来写是为了更好的使用vector定义不同的数据类型,使得更加方便

1、首先是私有部分

2、插入数据,扩容

要新定义一个tmp,是因为_start已经更新,不是原来的,所以提前保存未改变前的_start。

有效迭代器不可能是0 所以不要考虑pos==0.

3、规定没有实例化的类模板里面取东西,编译器不能区分着const_iterator,是类型还是静态变量

故直接改成 auto it = v.begin()即可。真香!!!

4、 迭代器失效

a、类似于野指针(扩容的时候)

此时已经扩容,但是pos仍然在旧空间

b、位置意义已经变了(未扩容)

eg.p=v.insert(p,40);

(*(p+1))*=10;

由于数据挪动,p已经不是指向3,所以insert以后我们认为迭代器也失效了,不要访问

4、在任意位置插入数据

5、删除数据

6、初始化

只要写了析构函数,就必须同时写拷贝构造函数和拷贝,来完成深拷贝,避免浅拷贝带来的崩溃和逻辑错误,不写构造则会默认生成,但是只要有构造函数就不会默认生成,所以不能值写拷贝构造,构造函数也必须写

7、

清空容器中的所有元素,通过将_finish指针重置回_start的位置,逻辑上删除了所有的元素。

8、两种赋值

9、最后再看一个由于memcpy而产生的一种问题

·

这里的第二次打印,第一行应该是乱码,是因为调用了析构,释放了临时变量,出现了随机值,所以进行深拷贝,问题要出在memcpy里面,两个对象析构时,都会去delete\[\]同一块内存,程序崩溃,旧内存被释放,成了野指针,故改成如下格式

相关推荐
小欣加油3 小时前
leetcode1926 迷宫中离入口最近的出口
数据结构·c++·算法·leetcode·职场和发展
星恒随风4 小时前
C++ 类和对象入门(五):初始化列表、explicit 和 static 成员详解
开发语言·c++·笔记·学习·状态模式
浪客灿心5 小时前
项目篇:模块设计与实现
数据库·c++
牛油果子哥q5 小时前
【C++ STL vector】C++ STL vector 终极精讲:动态数组底层原理、两倍扩容机制、迭代器失效、增删查改、性能剖析与工程避坑指南
开发语言·c++
为何创造硅基生物7 小时前
独占指针的创建std::make_unique 本身自带堆出现
c++
kyle~7 小时前
ROS 2 与 Isaac Sim 联合仿真(一)体系架构、环境选型与基础通信闭环
c++·机器人·nvidia·仿真·ros2
努力努力再努力wz7 小时前
【内存管理与高并发内存池系列】从 mmap 到 malloc:文件映射、匿名映射与 glibc 内存分配机制详解
linux·c语言·数据结构·数据库·c++·qt·链表
八解毒剂8 小时前
数据结构-平衡二叉树——对二叉搜索树的优化
数据结构·c++·算法
起床困难户5758 小时前
条款20:协助完成返回值优化
c++
啦啦啦啦啦zzzz8 小时前
算法总结(二分查找、双指针)
c++·算法