在这种情况下如何使用unique_ptr
How do I use unique_ptr in this scenario?
我对这段代码有问题:
A* a = createAnAObject().get();
其中 createAnAObject() 返回unique_ptr
问题是我必须这样做:
x.setA(a); // Pass ownership here
并且X
对象必须拥有A
对象的所有权,但是,据我了解,unique_ptr::get()
创建一个临时对象,该对象超出下一行的范围并调用析构函数,删除我的A
对象?
我该怎么办?我无法将接口更改为X
对象。
我认为我需要将所有权传递给非unique_ptr,因为我无法将 X 类更改为具有unique_ptr。
无需调用get
,不如调用 release
,这将为您提供底层指针并释放所有权。
A* a = createAnAObject().release();
如果您在两次调用之间有任何其他代码,我建议您在调用setA
之前保持std::unique_ptr
,以便在出现问题时不会有任何泄漏:
auto a_ptr = createAnAObject();
//...
x.setA(a_ptr.release());
要添加替代答案,setA()
可能应该按值std::unique_ptr
,因为它打算声明所有权,因此代码可能变为:
auto a_ptr = createAnAObject();
//...
x.setA(std::move(a_ptr));
因此看不到丑陋的.release()
。 毕竟,如果setA()
做的第一件事就是抛出异常,会发生什么? 现在你有一个指针,它逃脱了它被正确释放它的东西拥有的保护。
编辑:如果你不能改变X(并因为他们的次优实现而感到羞耻),那么你就会被困在.release
。
调用释放,定义如下:unique_ptr它放弃所有权并可分配给您的 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错误