std::unique_ptr<T,Deleter>::release

来自cppreference.com
< cpp‎ | memory‎ | unique ptr
 
 
工具库
语言支持
类型支持(基本类型、RTTI)
库功能特性测试宏 (C++20)
动态内存管理
程序工具
协程支持 (C++20)
变参数函数
调试支持
(C++26)
三路比较
(C++20)
(C++20)(C++20)(C++20)
(C++20)(C++20)(C++20)
通用工具
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中弃用)
整数比较函数
(C++20)(C++20)(C++20)   
(C++20)
交换类型运算
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
常用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
初等字符串转换
(C++17)
(C++17)

 
动态内存管理
未初始化内存算法
受约束的未初始化内存算法
分配器
垃圾收集器支持
(C++11)(C++23 前)
(C++11)(C++23 前)
(C++11)(C++23 前)
(C++11)(C++23 前)
(C++11)(C++23 前)
(C++11)(C++23 前)



 
 
pointer release() noexcept;
(C++11 起)
(constexpr since C++23)

若存在,则释放被管理对象的所有权。

调用后 get() 返回 nullptr

调用方负责清理该对象(例如使用 get_deleter())。

参数

(无)

返回值

指向被管理对象的指针,或若无被管理对象则为 nullptr,即调用前 get() 会返回的值。

示例

#include <cassert>
#include <iostream>
#include <memory>
 
struct Foo
{
    Foo() { std::cout << "Foo\n"; }
    ~Foo() { std::cout << "~Foo\n"; }
};
 
// Foo 资源的所有权在调用该函数时被转移
void legacy_api(Foo* owning_foo)
{
    std::cout << __func__ << '\n';
    // 没有人能理解或再敢碰的遗留代码
    // ...
    delete owning_foo;
}
 
int main()
{
    std::unique_ptr<Foo> managed_foo(new Foo);
    // [可能包括返回或抛异常逻辑的代码]
    // [...]
    legacy_api(managed_foo.release());
 
    assert(managed_foo == nullptr);
}

输出:

Foo
legacy_api
~Foo

参阅

返回指向被管理对象的指针
(公开成员函数)
返回用于析构被管理对象的删除器
(公开成员函数)
替换被管理对象
(公开成员函数)