是否允许将unique_ptr分配给shared_ptr?
is assigning unique_ptr to shared_ptr allowed?
std::map<std::string, std::shared_ptr<SomeClass>> map_string_to_object_pointer;
map_string_to_object_pointer["abcd"] = std::make_unique<SomeClass>();
问题是关于为shared_ptr分配unique_ptr。这是一个现有的代码,因此只是试图了解它是一个糟糕的编程还是分配给唯一的shared_ptr隐式地将unique_ptr转换为共享?因此,没有编译器警告。
是的,这会调用相应的赋值运算符:
template< class Y, class Deleter >
shared_ptr& operator=( std::unique_ptr<Y,Deleter>&& r );
构造函数和赋值都存在这样的重载(即使0_o接受std::auto_ptr
。
实际上只有一种糟糕的编程实践:在没有真正知道自己在做什么的情况下做某事。其他一切都是完全可以接受的。
相关文章:
- CLANG 编译器 说:变量"PTR"可能未初始化
- 在以唯一ptr为值的C++映射中,动态内存何时会被销毁
- 将 ptr 传递给 ptr 到 A 作为参数传递给 A 的函数是不好的做法吗?
- 为共享 ptr 向量实现复制 c'tor?
- 字符和整数中 **(ptr+1) 的值差异
- C++:在不中断共享的情况下通过引用传递共享 PTR?
- 如何将派生类从基 ptr 分配给 nlohmann::json
- 引用 std::shared:ptr 以避免引用计数
- 为什么我不能在不进行任何转换的情况下将浮点数放入任何类型的 ptr 中?
- 在调用函数时,ptr** 和 ptr*& 之间是否有区别,或者首选C++?
- 另一种类型的智能ptr,比如具有弱refs的unique_ptr
- 尝试打印出 *ptr++ 的值,以了解它是如何工作的
- 如何控制共享 ptr 引用计数?
- dopen():不以 root 身份运行时"failed to map segment from shared object"
- C++中的指针否定 (!ptr == NULL)
- 从const ptr*转换为ptr*时出现问题
- 无法使用 libtool 将 -shared 参数传递给 g++
- boost::shared_ptr和std::shared-ptr的同居
- 我可以用std::shared_ptr而不是boost::shared-ptr构建boost库吗
- shared-ptr-C++shared_ptr与unique_ptr用于资源管理