stl之序列容器——vector

         vector内部维护了start,finish,end_of_storage三个迭代器,分别表示目前使用空间的头、尾及目前可用空间的尾。当空间不够使用时,会动态增长。

一些常用的元素操作方法如下:

front    //第一个元素

back   //最后一个元素

push_back   //将一个元素插入vector尾部

insert    //指定位置插入

pop_back   //清除最后一个元素

erase   //清除某个元素

begin

end

resize   //调整容量方法

reserve  //保留n个空间的方法,在知道vector的容量下,调用此方法可以提高效率,避免vector的重建

size 元素的个数

capacity // vector的空间大小 >= size

empty 其实现如下:

bool empty() const
    {return begin() == end(); }      

clear  //本质上是调用了erase,只是析构了对象,但并没有销毁空间,如果要销毁空间,请用swap,用法如下:

{
	vector<T> vecTemp;
	vecTemp.swap(vec);   //vec为待释放的对象,这样离开作用域后对象会被释放
}

其调用了algorithm中的swap,实现如下:

 void swap(vector<_Tp, _Alloc>& __x) {
   __STD::swap(_M_start, __x._M_start);
   __STD::swap(_M_finish, __x._M_finish);
   __STD::swap(_M_end_of_storage, __x._M_end_of_storage);
  }

         vector的插入操作(调用insert和push_back),如果可用空间不足的话,vector会重新分配空间(重分配的空间为原来的2倍,或2倍以上),然后将原内容拷贝过去并释放原来的空间。因此,对vector的任何操作,一旦引起空间重新配置,指向原vector的所有迭代器就都失效了。

         vector支持随机存储操作,其使用的迭代器是RandomAccessIterator

         当已知插入元素的数量时,可以事先使用reserve函数来分配足够大小的内存,防止内存的重复分配和释放,提高效率。vector的插入和删除操作效率较差,如果这两种操作比较频繁,请使用list或set/map。

需要指出的是,vector是非异步安全的,如涉及多线程操作的话,需要自行采取同步措施。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值