c – 不能在没有指针的情况下在循环中构造实例吗?

栏目: C · 发布时间: 7年前

内容简介:翻译自:https://stackoverflow.com/questions/32299113/is-it-not-possible-to-construct-instances-in-a-loop-without-a-pointer
这段代码会爆炸,对吗?一旦循环退出,原始实例将与其所有内部成员一起死亡,因此如果它们不是POD,任何需要访问B成员的do_stuff方法都会抛出分段错误,对吗?
void foo() {
  std::vector<B> bar;
  for (int i = 0; i < 7; i++)
    bar.push_back(B(i, i, i));
  bar[3].do_stuff();
}

那么,有没有办法在不使用指针的情况下做到这一点?

或者你必须这样做:

void foo() {
  std::vector<B*> bar;
  for (int i = 0; i < 7; i++)
    bar.push_back(new B(i, i, i));
  bar[3]->do_stuff();
  for (int i = 0; i < 7; i++)
    delete bar[i];
}

第一个代码比第二个代码好.

B实例将是 moved since C++11 / copiespre-C 11到向量中,因此它们不会在循环后超出范围 – 仅在向量超出范围之后.

如果您想获得绝对最佳的性能,请执行以下操作:

void foo() {
  std::vector<B> bar;
  bar.reserve(7);
  for (int i = 0; i < 7; i++)
    bar.emplace_back(i, i, i);
  bar[3].do_stuff();
}

这将保证只有一次重新分配,并且根据Marc Glisse的评论,元素直接在向量内部构建(而不是在那里移动或复制它们).

翻译自:https://stackoverflow.com/questions/32299113/is-it-not-possible-to-construct-instances-in-a-loop-without-a-pointer


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

智能优化方法

智能优化方法

汪定伟 / 2007-4 / 37.10元

《智能优化方法》主要介绍近年来产生发展的多种智能优化算法。包括为人熟知的遗传算法、禁忌搜索算法、模拟退火算法和蚁群优化算法;近年来已成为研究热点的粒子群优化算法;还有尚待普及的捕食搜索算法和动态环境下的进化计算。书中讨论这些算法的产生和发展、算法的基本思想和理论、基本构成、计算步骤和主要的变形以及数值例子和实际应用。为了方便读者学习,各章之后还附有精选的习题、思考题及相关的参考文献。 本教材......一起来看看 《智能优化方法》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具