命名空间
变体
操作

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

来自 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)



 
 
~unique_ptr();
(自 C++11 起)
(自 C++23 起为 constexpr)

如果 get() == nullptr 则没有效果。否则,将通过 get_deleter()(get()) 销毁拥有对象。

要求 get_deleter()(get()) 不抛出异常。

[编辑] 注释

虽然使用默认删除器的 std::unique_ptr<T> 可以使用 不完整类型 T 构造,但类型 T 必须在调用析构函数的代码处是完整的。

[编辑] 示例

以下程序演示了自定义删除器的用法。

#include <iostream>
#include <memory>
 
int main () 
{
    auto deleter = [](int* ptr)
    {
        std::cout << "[deleter called]\n";
        delete ptr;
    };
 
    std::unique_ptr<int, decltype(deleter)> uniq(new int, deleter);
    std::cout << (uniq ? "not empty\n" : "empty\n");
    uniq.reset();
    std::cout << (uniq ? "not empty\n" : "empty\n");
}

输出

not empty
[deleter called]
empty