使用单一实例时内存泄漏

Memory leaks when using a singleton

本文关键字:内存 泄漏 实例 单一      更新时间:2023-10-16

我有一个实现辛格尔顿设计模式的类。我知道有些人认为这不是一个好主意,但它有很大帮助,

无论如何 - 我有一个内存泄漏,弗拉格林德指出我这些行:

_singleton = new Manager(); //Manager::instance() (Manager.cpp:18)

Manager::Manager() : _file(new ofstream), _tasks(new map<int, Task *>()),
        _idState(new map<int, int>()), _closing(false), _pending(false),
        _lock(new pthread_mutex_t), _endLock(new pthread_mutex_t),  _cond(new pthread_cond_t),
        _flushCond(new map<int, pthread_cond_t *>()), _attr(new pthread_attr_t) {
//The last line is line 25 in Manager::Manager

现在在管理器的析构函数中,我无法显式删除它,因为它创建了一个愚蠢的循环(因为在删除时将调用析构函数_singleton导致无限循环)。如何清除此泄漏?谢谢!

附言这是瓦尔格林德的输出:

==17823== 512 bytes in 1 blocks are definitely lost in loss record 2 of 2
==17823==    at 0x4C27297: operator new(unsigned long) (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==17823==    by 0x40151E: Manager::Manager() (Manager.cpp:25)
==17823==    by 0x4014DB: Manager::instance() (Manager.cpp:18)
==17823==    by 0x406475: initdevice(char*) (outputdevice.cpp:66)
==17823==    by 0x4061D5: main (driver.cpp:21)
==17823== 
==17823== LEAK SUMMARY:
==17823==    definitely lost: 512 bytes in 1 blocks
=    =17823==    indirectly lost: 0 bytes in 0 blocks
==17823==      possibly lost: 288 bytes in 1 blocks
==17823==    still reachable: 0 bytes in 0 blocks
==17823==         suppressed: 0 bytes in 0 blocks

另外:这是我创建管理器的代码:

Manager.h:
class Manager {
public:
    ~Manager();
    static Manager * instance();
private:
    Manager();
    static Manager * _singleton;
};

和实现:

Manager.cpp:
Manager * Manager::_singleton = 0;
Manager * Manager::instance() {
    if (!_singleton)
        _singleton = new Manager();
    return _singleton;
}

在 C++ 中实现单例的一种常见方法是使实例成为实例 getter 中的函数静态std::unique_ptr<T>,而不是类静态变量。这确保了在程序完成时对析构函数的调用,并允许您创建一个多态访问的实例,例如通过指向抽象基类的指针。

斯科特·迈耶斯(Scott Meyers)在他的"更有效C++"一书中对这个话题进行了很好的讨论。

使Manager成为静态对象,它的构造函数和析构函数将自动调用。 或者,如果必须使用运算符 new 分配它,请将其放在智能指针中(如果可以的话,unique_ptr,否则auto_ptr),以便在指针时将其销毁。