shared_ptr智能指针的释放和删除器的问题。

发布于 2022-09-02 11:28:31 字数 651 浏览 37 评论 0

template<typename T>
class shared_ptr
{
    T *_ptr;
    std::size_t *count;
    std::function<void(T*)> del{ DebugDelete() };        //DebugDelete只是delete 指针
    //....
public:
    shared_ptr(T *t = new T, std::function<void(T*)> f=DebugDelete) 
        :_ptr(t), count(new std::size_t(1),del(f) {}
    //....
    ~shared_ptr()
    {
        if (--*count == 0)
        {
            del(_ptr);            //删除器
            delete count;
        }
    }
};

但是这样就和库的shared_ptr的使用不一样了,例如原版的shared_ptr定义一个指向vector<int>的指针:shared_ptr<vector<int>> vint_ptr;
它不用指定删除器,这是怎么实现的?在删除器下工夫?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

淡水深流 2022-09-09 11:28:31

标准库里shared_ptr构造函数里第二个参数允许你自定义一个deleter用来析构的时候释放资源。如果不指定的话它就单纯的delete掉这个raw pointer。vector这种不负责持有资源的类型不需要定制一个deleter。

陌若浮生 2022-09-09 11:28:31

你这个构造函数我看的觉得好像有点问题:

  shared_ptr(T *t = new T, std::function<void(T*)> f=DebugDelete) 
        :_ptr(t), count(new std::size_t(1),del(f()) {}

f 只是个类名字, del 需要一个可调用对象初始化阿

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文