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,则相当于亲自干预这个分配,如果你能大致算出你要的空间的上限,当然你指定会更高效/节约内存。但是如果你也不能确定,那么还不如不指定。

    评论

报告相同问题?

悬赏问题

  • ¥30 这是哪个作者做的宝宝起名网站
  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!