尝试从向量中获取unique_ptr元素后出错

时间:2013-12-25 13:35:58

标签: c++ vector unique-ptr

我了解了如何将unique_ptr<T>插入vector<unique_ptr<T>>Why can I not push_back a unique_ptr into a vector?

但是如何获得一个元素呢?我举了一个例子:

#include <memory>
#include <vector>

class A {
  public:
    A(int x, int y){
      x_ = x;
      y_ = y;
    }
  private:
    int x_;
    int y_;
};


int main(){
  std::vector<std::unique_ptr<A>> vec_a;
  std::unique_ptr<A> tmp_a = std::unique_ptr<A>(new A(13,32));

  vec_a.push_back(std::move(tmp_a));

  vec_a.push_back(std::unique_ptr<A>(new A(3,2)));

  // error
  std::unique_ptr<A> a = vec_a.at(0);
}

我收到此错误消息:

main.cc: In function ‘int main()’:
main.cc:24:36: error: use of deleted function 
      ‘std::unique_ptr<_Tp, _Dp>::unique_ptr(const std::unique_ptr<_Tp, _Dp>&) 
      [with _Tp = A; _Dp = std::default_delete<A>]’
   std::unique_ptr<A> a = vec_a.at(0);
                                    ^
In file included from /usr/include/c++/4.8/memory:81:0,
                 from main.cc:1:
/usr/include/c++/4.8/bits/unique_ptr.h:273:7: error: declared here
       unique_ptr(const unique_ptr&) = delete;
       ^

我做错了什么?我该怎么办?为什么这不起作用?

2 个答案:

答案 0 :(得分:13)

无法复制或分配

unique_ptr。它需要移动复制或移动分配。您可以使用std::move

来实现此目的
std::unique_ptr<A> a = std::move(vec_a.at(0));

std::move的调用基本上允许您将RHS视为右值,然后可以在unique_ptr'移动复制构造函数中使用。

请注意,在此之后,您必须小心vec_a的第一个元素。

如果您不想将指针的所有权从向量中取出,只需直接访问托管指针:

A* a = vec_a.at(0).get();

在指向的对象不再存在之后,您必须小心不要使用a

答案 1 :(得分:5)

这是一个unique_ptr,你正在尝试制作副本。一种解决方法是改为使用原始指针:

A* a = vec_a.at(0).get();

请记住,向量仍将拥有指针,并且当向量超出范围时仍将删除它。