命名空间
变体
操作

std::get_deleter

来自 cppreference.cn
< cpp‎ | 内存‎ | shared ptr
 
 
内存管理库
(仅作说明*)
未初始化内存算法
(C++17)
(C++17)
(C++17)
受约束的未初始化
内存算法
C 库

分配器
内存资源
垃圾回收支持
(C++11)(直到 C++23)
(C++11)(直到 C++23)
(C++11)(直到 C++23)
(C++11)(直到 C++23)
(C++11)(直到 C++23)
(C++11)(直到 C++23)
未初始化存储
(直到 C++20*)
(直到 C++20*)
显式生命周期管理
 
 
定义于头文件 <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> 的公共成员函数) [编辑]