使用就地元素构造向量

时间:2015-03-15 18:37:11

标签: c++ c++14

我有一个智能指针的向量。到目前为止,我可以在这样的循环中构造它们:

std::vector<std::unique_ptr<int>> v(10);
for (int i = 0; i < 10; ++i)
    v.emplace_back(std::make_unique<int>());

我不想这样做。我想要以下内容:

std::vector<std::unique_ptr<int>> v(10, std::make_unique<int>());

这不起作用。看起来vector只有一个构造函数,可以创建副本或默认插入。那么我可以做到这一点吗?如果答案是否定的,那么推理是什么?在将来,我希望看到一个允许上述内容的构造函数。

2 个答案:

答案 0 :(得分:5)

您可以使用算法生成:

std::vector<std::unique_ptr<int>> v(10);
std::generate (v.begin(), v.end(), []() { return std::make_unique<int>(); });

答案 1 :(得分:2)

template<class T, class A, class F>
std::vector<T, A> generate_vec( size_t n, F&& f ){
  std::vector<T, A> retval;
  retval.reserve(n);
  std::generate_n( std::back_inserter(retval), n, std::forward<F>(f) );
  return retval;
}
// usually you don't want to bother to pass an allocator:
template<class T, class F>
std::vector<T> generate_vec( size_t n, F&& f ){
  return generate_vec<T, std::allocator<T>>( n, std::forward<F>(f) );
}

现在

auto v=generate_vec<std::unique_ptr<int>>(
  30,
  []{return std::make_unique<int>(); }
);

做你想做的事。

live example