将派生类的unique_ptr添加到基类unique_ptr的vector上
Add unique_ptr of derived class to vector of base class unique_ptr
我有一个std::unique_ptr<Derived>
,我想添加到std::vector<std::unique_ptr<Base>>
。
std::unique_ptr<Derived> derivedObject;
std::vector<std::unique_ptr<Base>> vec;
vec.push_back(derivedObject) // Invalid arguments
unique_ptr保证它只有一个指向内存的指针,所以你不能只是把它复制到vector中,你需要移动它:
vec.push_back(std::move(derivedObject));
如果您查看unique_ptr构造函数(http://en.cppreference.com/w/cpp/memory/unique_ptr/unique_ptr),您会发现这个类没有实现复制构造函数,而是实现移动构造函数(http://en.cppreference.com/w/cpp/language/move_constructor)。
这是因为您无法复制std::unique_ptr
。使用std::move()
:
#include <iostream>
#include <memory>
#include <vector>
struct Base {
};
struct Derived : public Base {
};
int main()
{
std::unique_ptr<Derived> derivedObject;
std::vector<std::unique_ptr<Base>> vec;
vec.push_back(std::move(derivedObject));
// ^^^^^^^^^^ ^
}
cppreference about unique_ptr
如果T是某基B的派生类,则std::unique_ptr
隐式转换为std::unique_ptr .
所以,问题不在于转换失败。
类满足MoveConstructible和MoveAssignable的要求,但不满足CopyConstructible和CopyAssignable的要求。
这就是导致失败的原因。unique_ptr
可以移动,但不能复制,因为这会破坏单一所有权协议。
所以要么使用std::move
,要么直接使用make_derived
vec.push_back(std::move(derivedObject)); //Option 1. When unique_ptr is already created.
OR,
vec.push_back(make_unique<Derived>()); //Option 2. New unique_ptr
使用选项#2,您可以避免有一个没有目的的局部变量。无论如何,当在unique_ptr
上执行move
时,unique_ptr
拥有的对象被释放了。演示。
相关文章:
- 为什么 std::unique 不调用 std::sort?
- CLANG 编译器 说:变量"PTR"可能未初始化
- 在以唯一ptr为值的C++映射中,动态内存何时会被销毁
- 将 ptr 传递给 ptr 到 A 作为参数传递给 A 的函数是不好的做法吗?
- 为共享 ptr 向量实现复制 c'tor?
- 字符和整数中 **(ptr+1) 的值差异
- C++:在不中断共享的情况下通过引用传递共享 PTR?
- 生成"unique"矩阵
- 如何将派生类从基 ptr 分配给 nlohmann::json
- 引用 std::shared:ptr 以避免引用计数
- 我对 std::unique(算法)C++有问题
- 为什么我不能在不进行任何转换的情况下将浮点数放入任何类型的 ptr 中?
- 在调用函数时,ptr** 和 ptr*& 之间是否有区别,或者首选C++?
- 另一种类型的智能ptr,比如具有弱refs的unique_ptr
- 尝试打印出 *ptr++ 的值,以了解它是如何工作的
- 如何控制共享 ptr 引用计数?
- std::shared_ptr::unique(),复制和线程安全
- 如何在C++03中用自定义谓词调用std::unique
- C++中的指针否定 (!ptr == NULL)
- C++14 unique_ptr并使用已删除的函数'std::unique-ptr' unique_ptr错误