У меня есть класс, в котором я реализую шаблон дизайна singelton. Я знаю, что некоторые люди не думаю, что его хорошая идея, но это очень помогает,Утечка памяти при использовании singleton
Во всяком случае - у меня есть утечка памяти и vlagrind указывает мне на эти строки:
_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, приводящем к бесконечному циклу). Как избавиться от этой утечки? Благодаря!
P.s. вот выход valgrind есть:
==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;
}
«Теперь в деструкторе менеджера я не могу явно удалить его, потому что он создает глупую петлю». - что это значит? –
покажите нам, как вы создаете и уничтожаете экземпляр менеджера. – Zuljin
Не делайте этого с указателями, и он работает намного лучше. http://stackoverflow.com/a/1008289/14065 Он даже становится потокобезопасным на gcc (см. примечания в связанном вопросе). Даже если вы используете указатели, вы никогда не должны возвращать указатель, вы должны вернуть ссылку из 'instance()' в противном случае вызывающий не уверен, что они должны удалить объект, и они никогда не должны. –