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

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

内容简介:翻译自: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


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

查看所有标签

猜你喜欢:

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

Java算法

Java算法

塞奇威克 / 赵文进 / 清华大学出版社 / 2004-06-01 / 59.0

《Java算法》用Java语言全面实现了当今最重要的计算机算法,并用大量图表和数学公式对算法进行了详尽的描述和分析。全书共分3卷,本书是其中的第1卷(第1至第4部分)。内容包括基本概念(第1部分)、数据结构(第2部分)、排序算法(第3部分)和查找算法(第4部分)。本书概念清楚,内容翔实,新颖,由浅入深地描述了算法。本书可作为高等院校计算机相关专业本科生和研究生的教材和补充读物,也可作为Java爱好一起来看看 《Java算法》 这本书的介绍吧!

html转js在线工具
html转js在线工具

html转js在线工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具