wWX336815 2018-11-27 10:53 采纳率: 33.3%
浏览 469

vector的resize方法的一个疑问?

#include
#include
using namespace std;
int main()
{
    vector vc;
    vc.resize(10);
    vc.resize(vc.size()+1,5);
    for(vector::iterator iter = vc.begin();iter != vc.end();++iter){
        cout << *iter << endl;
    }
}

无意中看到的一种实现,外界setvalue的时候,函数里面对vector类似上面这种操作,而没有直接使用push_back,有谁知道是这样写实更有效率还是?

  • 写回答

1条回答

  • threenewbee 2018-11-27 11:47
    关注

    vector内部使用一个数组来存储你push进去的元素。当你添加的数据过多,数组容纳不下的时候,它会自动创建一个更大的数组,然后搬过去。
    默认的情况下,vector会做一个平衡:如果分配的数组太大,那么浪费存储,如果分配的数组太小,就要不断重新分配,所以它选取的是一个折衷的方案。
    而你用resize,则相当于亲自干预这个分配,如果你能大致算出你要的空间的上限,当然你指定会更高效/节约内存。但是如果你也不能确定,那么还不如不指定。

    评论

报告相同问题?

悬赏问题

  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘
  • ¥15 perl MISA分析p3_in脚本出错
  • ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
  • ¥15 ubuntu虚拟机打包apk错误
  • ¥199 rust编程架构设计的方案 有偿
  • ¥15 回答4f系统的像差计算
  • ¥15 java如何提取出pdf里的文字?