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;
它不用指定删除器,这是怎么实现的?在删除器下工夫?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
标准库里shared_ptr构造函数里第二个参数允许你自定义一个deleter用来析构的时候释放资源。如果不指定的话它就单纯的delete掉这个raw pointer。vector这种不负责持有资源的类型不需要定制一个deleter。
你这个构造函数我看的觉得好像有点问题:
f 只是个类名字, del 需要一个可调用对象初始化阿