跳到主要内容

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

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

如果 get() == nullptr,则没有任何效果。否则,所拥有的对象将通过 get_deleter()(get()) 进行销毁。

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

备注

尽管可以使用不完整类型的 T 来构造具有默认删除器的 std::unique_ptr<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

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

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

如果 get() == nullptr,则没有任何效果。否则,所拥有的对象将通过 get_deleter()(get()) 进行销毁。

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

备注

尽管可以使用不完整类型的 T 来构造具有默认删除器的 std::unique_ptr<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