std::get_deleter
来自cppreference.com
< cpp | memory | shared ptr
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
实例占有返回的指针,它就合法。
注意
返回的指针可能比最后一个 shared_ptr
的生存期更持久,例如,还剩下 std::weak_ptr 时且实现在销毁整个控制块前不销毁删除器。
示例
演示 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; { // 创建拥有一个 Foo 和删除器的 shared_ptr auto foo_p = new Foo; std::shared_ptr<Foo> r(foo_p, foo_deleter); aptr = std::shared_ptr<int>(r, &r->i); // 别名使用构造函数 // aptr 现在指向 int ,但管理整个 Foo } // r 被销毁(不调用删除器) // 获得指向删除器的指针: 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"; } // 于此调用删除器
输出:
shared_ptr<int> owns a deleter ...and it equals &foo_deleter foo_deleter called!
参阅
std::shared_ptr 构造函数 (公开成员函数) |