2

我是智能指针的新手,我喜欢将它们用于共享对象的安全性和强大功能......

我有一个问题:如果我的类在其构造函数和析构函数中管理资源,应用一些经验法则,如 Big 5 和 Big 3……我还应该使用智能指针吗?或者我的班级是他们的替代品。因为正如我在 C++ 入门 5 版中读到的那样,智能指针可以解决原始指针面临的问题,例如内存泄漏、双重删除指针和访问悬空指针……我的班级可以避免这些问题:

class BallGame {
    public:
        using Resource = int;

        BallGame(int);
        BallGame(const BallGame&);
        BallGame(BallGame&&);
        BallGame& operator=(const BallGame&);
        BallGame& operator=(BallGame&&);
        ~BallGame();
    private:
        Resource m_res;
};
  • 考虑到我班级的成员正在做正确的工作,所以我可以避免使用智能指针吗?

  • 我想知道一些我应该使用智能指针而不是在我的班级中管理资源的场景。

  • 它们真的像 C++ 入门书中那样用于“愚蠢的类”(定义构造函数但没有表现良好的析构函数的类)。

4

3 回答 3

5

您的问题可以理解为

如果我在我使用的每个类中手动实现智能指针的内存所有权的正确语义,我可以避免使用智能指针吗?

的,但为什么呢?当您需要一个动态数组时,您是否std::vector每次需要时都手动重新实现基本语义?我不这么认为。

这是图书馆的目的,避免每次都重新发明轮子。

于 2019-10-30T23:07:54.637 回答
1

尚未提及的智能指针的另一个好处是,它们使阅读代码的人对该对象的生命周期有一个不错的了解。带有原始指针的事情是(尤其是随着代码变得越来越复杂),可能很难弄清楚谁负责对对象调用 delete,而如果您有一个唯一指针,我们会立即知道删除将在指针超出范围。

于 2019-10-30T23:25:43.393 回答
0

正如您在书中所读到的那样:他们解决了原始指针面临的问题:考虑一下:

int* ptr = new int[1024];
// oh my God! forgot to free it then welcome to memory leak

std::string* pStr = new std::string("Hello");
delete pStr;

//...
// and at some point in the program you think it is time to free pStr which has been already freed (among hundreds of code lines) then welcome to U.B.
 std::cout << *pStr << std::endl; // pStr is a dangling pointer. U.B

要使用智能指针解决此问题:

std::unique_ptr<int> upi = std::make_unique(7);
// use upi effectively and don't care about freeing it because it automatically will be freed for you.
  • 你的类不能支持的另一个原因是在许多对象之间有效地共享同一个对象。事实上,你可以通过在你的类中应用浅拷贝来实现这一点,但问题是谁将释放该资源,然后你最终在你的小类中实现 shared_ptr 的功能!

  • 每个新版本的 C++ 都带有新的工具和新的强大功能,因此您应该坚持使用这些库,而不是重新发明井。如果只是出于某种教育原因,那么练习是可以的。

  • 如果你看你会发现真正的程序包含智能指针作为成员,这使你的类变得健壮。

于 2019-10-30T23:17:03.800 回答