std::get_deleter
来自 cppreference.cn
< cpp | 内存 | shared ptr
定义于头文件 <memory> |
||
template< class Deleter, class T > Deleter* get_deleter( const std::shared_ptr<T>& p ) noexcept; |
(C++11 起) | |
访问 p 的删除器。如果共享指针 p 拥有一个 cv 非限定 `Deleter` 类型的删除器(例如,如果它是用一个将删除器作为参数的构造函数创建的),则返回一个指向该删除器的指针。否则,返回空指针。
目录 |
[编辑] 参数
p | - | 一个需要访问其删除器的共享指针。 |
[编辑] 返回值
一个指向所拥有的删除器的指针,或 nullptr。返回的指针至少在仍然存在至少一个拥有它的 shared_ptr 实例时有效。
[编辑] 注意
如果例如 std::weak_ptr 仍然存在,并且实现直到整个控制块被销毁才销毁删除器,则返回的指针可能比最后一个 shared_ptr 实例寿命更长。
[编辑] 示例
演示 std::shared_ptr 的删除器独立于 shared_ptr 的类型。
运行此代码
#include <iostream> #include <memory> struct Foo { int i; }; void foo_deleter(Foo* p) { std::cout << "foo_deleter called!\n"; delete p; } int main() { std::shared_ptr<int> aptr; { // create a shared_ptr that owns a Foo and a deleter auto foo_p = new Foo; std::shared_ptr<Foo> r(foo_p, foo_deleter); aptr = std::shared_ptr<int>(r, &r->i); // aliasing ctor // aptr is now pointing to an int, but managing the whole Foo } // r gets destroyed (deleter not called) // obtain pointer to the deleter: if (auto del_p = std::get_deleter<void(*)(Foo*)>(aptr)) { std::cout << "shared_ptr<int> owns a deleter\n"; if (*del_p == foo_deleter) std::cout << "...and it equals &foo_deleter\n"; } else std::cout << "The deleter of shared_ptr<int> is null!\n"; } // deleter called here
输出
shared_ptr<int> owns a deleter ...and it equals &foo_deleter foo_deleter called!
[编辑] 另请参阅
std::shared_ptr 构造函数 (公开成员函数) | |
返回用于销毁托管对象的删除器 ( std::unique_ptr<T,Deleter> 的公共成员函数) |