【STL】verctor的简单剖析以及各种函数的实现

概述vector其实和array数组挺像的,但是vector之所以存在的原因是: vector是动态空间,随着元素的增加,它的内部机制会自行扩建空间以容纳新的元素;而array是静态空间,一旦配置大小就不能改变了;vector的数据结构 vector有三个成员变量。 T* _start; //表示目前使用的空间头 T* _finish;//表示目前是的空间尾 T* _end
摘要由CSDN通过智能技术生成
概述

vector其实和array数组挺像的,但是vector之所以存在的原因是:
vector是动态空间,随着元素的增加,它的内部机制会自行扩建空间以容纳新的元素;而array是静态空间,一旦配置大小就不能改变了;

vector的数据结构
vector有三个成员变量。

    T* _start; //表示目前使用的空间头
    T* _finish;//表示目前是的空间尾
    T* _end_of_storage; //表示可用的空间尾。
//其实就是size大小和容量的大小

这里写图片描述

vector的构造和内存管理

所谓的动态增加容量,并不是在原来的空间后面连接新的空间,而是以原大小的两倍,另外配置一块空间,然后将原内容拷贝过来,然后在原内容之后构造新的内容,释放原来的空间,因此,对vector的操作,一旦引起空间重新配置的话,迭代器会失效。

这里写图片描述
这里写图片描述

vector的构造函数
//(1)默认空的构造函数1explicit vector ( const Allocator& = Allocator() );

//(2)构造n个对象,对象值为value的vector2explicit vector ( size_type n, const T& value= T(), const Allocator& = All
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值