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

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;
它不用指定删除器,这是怎么实现的?在删除器下工夫?

阅读 18.4k
2 个回答

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

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

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

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

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题