std::unique_ptr<T,Deleter>:: ~unique_ptr
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Member functions | ||||
|
unique_ptr::~unique_ptr
|
||||
| Modifiers | ||||
| Observers | ||||
| Non-member functions | ||||
|
(C++14)
(C++20)
|
||||
|
(until C++20)
(C++20)
|
||||
|
(C++20)
|
||||
| Helper classes | ||||
|
~unique_ptr
(
)
;
|
(since C++11)
(constexpr since C++23) |
|
If
get()
==
nullptr
there are no effects. Otherwise, the owned object is destroyed via
get_deleter()
(
get()
)
.
Requires that
get_deleter()(get())
does not throw exceptions.
Notes
Although
std::unique_ptr<T>
with the default deleter may be constructed with
incomplete type
T
, the type
T
must be complete at the point of code where the destructor is called.
Example
The following program demonstrates usage of a custom deleter.
#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"); }
Output:
not empty [deleter called] empty