内容简介:翻译自: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
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- NULL 指针、零指针、野指针
- 将数组和矩阵传递给函数,作为C中指针的指针和指针
- C语言指针数组和数组指针
- python(函数指针和类函数指针)
- Java类 静态代码块、构造代码块、构造函数初始化顺序
- C++ 基类指针和派生类指针之间的转换
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Spark技术内幕
张安站 / 机械工业出版社 / 2015-9-1
Spark是不断壮大的大数据分析解决方案家族中备受关注的新增成员。它不仅为分布式数据集的处理提供一个有效框架,而且以高效的方式处理分布式数据集。它支持实时处理、流处理和批处理,提供了AllinOne的统一解决方案,使得Spark极具竞争力。 本书以源码为基础,深入分析Spark内核的设计理念和架构实现,系统讲解各个核心模块的实现,为性能调优、二次开发和系统运维提供理论支持;本文最后以项目实战......一起来看看 《Spark技术内幕》 这本书的介绍吧!