通过保留和复制,还是通过创建和交换来复制向量更有效? [英] Is it more efficient to copy a vector by reserving and copying, or by creating and swapping?

查看:23
本文介绍了通过保留和复制,还是通过创建和交换来复制向量更有效?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试有效地制作矢量的副本.我看到两种可能的方法:

I am trying to efficiently make a copy of a vector. I see two possible approaches:

std::vector<int> copyVecFast1(const std::vector<int>& original)
{
  std::vector<int> newVec;
  newVec.reserve(original.size());
  std::copy(original.begin(), original.end(), std::back_inserter(newVec));
  return newVec;
}

std::vector<int> copyVecFast2(std::vector<int>& original)
{
  std::vector<int> newVec;
  newVec.swap(original);
  return newVec;
}

以下哪个是首选,为什么?我正在寻找最有效的解决方案,以避免不必要的复制.

Which of these is preferred, and why? I am looking for the most efficient solution that will avoid unnecessary copying.

推荐答案

如果您通过引用发送参数,您的第二个示例将不起作用.你的意思是

Your second example does not work if you send the argument by reference. Did you mean

void copyVecFast(vec<int> original) // no reference
{

  vector<int> new_;
  new_.swap(original); 
}

那行得通,但更简单的方法是

That would work, but an easier way is

vector<int> new_(original);

这篇关于通过保留和复制,还是通过创建和交换来复制向量更有效?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆