我过去经常使用这种方式复制数据,并在容器之间进行一些更改:
std::vector<Tsrc> source{Tsrc(),Tsrc(2),Tsrc(3),Tsrc(4)};
std::vector<Tdst> dst(source.size());
std::transform(begin(source),end(source),begin(dst),[](Tsrc& item){
return do_something(item);
}首先,以前的代码是标准和干净的吗?有什么增强措施可以应用吗?
其次,我现在也想做同样的事情,但是对于没有默认构造函数的Tdst。因此,上述代码将无法工作。我把它换成了:
std::vector<Tsrc> source{Tsrc(),Tsrc(2),Tsrc(3),Tsrc(4)};
std::vector<Tdst> dst;
dst.reserve(source.size());
for(auto& item:dst){
dst.emplace_back(do_something(item));
}这样做对吗?有什么建议吗?
发布于 2015-11-23 07:21:57
你正在做的事看上去很好。您可以使用std::back_inserter避免显式循环。此外,由于未修改原始范围的元素,因此应该将lambda的参数设置为const
dst.reserve(source.size());
std::transform(begin(source), end(source), back_inserter(dst),
[](const Tsrc& item){return do_something(item);});https://stackoverflow.com/questions/33865542
复制相似问题