C++ 中 vector 如何实现内存分配

<<C++ primer>>中对顺序容器的内存分配是这样描述的,内容太多,简写一下:


为了支持随机访问,vector中的元素采用顺序存放,即每一个元素紧挨着前一个元素进行存储。那么现在只有可能出现问题了,当内存中没有足够连续的空间去存放新插入来的元素怎么办,C++是这样处理的:重新分配内存空间,将原来旧的元素全部复制到新的存储空间中去,然后再插入新的元素。因此可以看出,如果内存不是特别充足或者内存中没有较大块的空闲空间的,向vector容器中插入元素可能会有相当大的CPU开销。其中最糟糕的情况是每次插入一个元素,程序要将所有的元素复制到一个新的内存块上去,当然对于这种情况c++作了一个折衷的处理:当我们插入元素时,如果老的内存块是连续空闲空间不够,则重新分配一块内存空间,内存空间的大小不是只比旧的内存空间大一个元素的大小,相反而是多分配几个元素空间大小,这样对于接下来的几个新插入元素做到有空间可以插入,这样之后使得vector的性能得到很大提高,不过这是一个折衷的办法。


上面分析完之后我们应该可以知道当调用push_back(Tobj)时是如何分配内存的,即是在最大插入这个元素即可。不过vector也支持随机插入元素,这要借用迭代器来完成这个工作了,看下面一段代码,猜测一下会有什么样的输出结果


 vector<int> vec;
 for(int i = 0; i < 10; i++)
      vec.push_back(i);
 vector<int>::iterator it = vec.begin();
 for(int i = 0; i < 5; i++)
       it++;
 cout<<&(*it)<<"   "<<*it<<endl;
 it = vec.insert(it , 33);
 cout<<&(*it)<<"   "<<*it<<endl;
 ++it;
 cout<<&(*it)<<"   "<<*it<<endl;

如果第一条输出语句是003B993C  5,那么后两条语句输出呢?


行啦,我给出来吧,具体原因可能要你自己去分析了,其实从上面的解释可以看出原因
003BB93C   33
003BB940   5


从这里你看出了什么问题,这里体现了vector一种怎么实现的思想,感觉是不是效率上有点低呢?


呵呵,是不是有点像数组的随机插入,要将插入点后的所有数据往后移动。这么说的话,可能没有用链表高效。


不过根据C++ primer作者给出的解释,vector的实际使用效率要比list和deque要高一点。主要还是要看应用场景吧。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值