c – 在shared_ptr的自定义删除中检查nullptr是否有意义?

我看到一些代码,使用std :: shared_ptr与一个自定义删除器来测试nullptr的参数,例如MyClass,它有一个close()方法,并用一些CreateMyClass构造:
auto pMyClass = std::shared_ptr<MyClass>(CreateMyClass(),[](MyClass* ptr)
                                        { 
                                            if(ptr) 
                                                ptr->close(); 
                                        });

删除器中测试ptr的空值是否有意义?
这可能发生吗?怎么样?

解决方法

构造函数std :: shared_ptr< T> :: shared_ptr(Y * p)要求删除p是有效的操作.当p等于nullptr时,这是一个有效的操作.

构造函数std :: shared_ptr< T> :: shared_ptr(Y * p,Del del)要求del(p)是有效的操作.

如果您的自定义删除器无法处理p等于nullptr,那么在shared_ptr的构造函数中传递null p是无效的.

您提供的构造函数可以更好地呈现,因此:

#include <memory>

struct MyClass {
    void open() {
        // note - may throw
    };

    void close() noexcept {
        // pre - is open
    }
};

struct Closer
{
    void operator()(MyClass* p) const noexcept
    {
        p->close();
        delete p;  // or return to pool,etc
    }
};

auto CreateMyClass() -> std::unique_ptr<MyClass,Closer>
{
    // first construct with normal deleter
    auto p1 = std::make_unique<MyClass>();

    // in case this throws an exception.
    p1->open();

    // Now it's open,we need a more comprehensive deleter
    auto p = std::unique_ptr<MyClass,Closer> { p1.release(),Closer() };
    return p;
}

int main()
{
    auto sp = std::shared_ptr<MyClass>(CreateMyClass());
}

请注意,shared_ptr现在不可能拥有一个空对象.

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...