log4cpp 内存泄漏 解决方法

以前一直自己写日志类的框架

最近了解了一下开源的,感觉功能很强大!呵呵

 

使用了老牌的log4cpp 竟然发现有内存泄漏的问题,大概读了一下代码,并找到了这个问题。现放出来让大家也了解下

 

感觉这可能是编程习惯问题,如果程序退出时,有些人觉得对象就没必要删除了,因为,整个程序已经退出了,系统会处理一些事情(哪些事情?)

但是,到了MFC下面,退出时出现这些提示,让人感觉非常不爽!

 

内存问题一共三个地方:

1.NDC 

对于不同的线程,有不同的数据需要保存,退出时自然需要释放。

解决方法,增加一个静态的函数

 

 

NDC.h

void NDC::clearCurrentThreadNDC()

{

_nDC.reset();

}

 

在所有用过日志的线程里,最后退出时,加上调用此函数的代码。

 

2. template class ThreadLocalDataHolder

解决方法:

MSThreads.hh

 

 

inline ~ThreadLocalDataHolder()

{

reset();

TlsFree(_key); 

};

 

 

3.Appender 需要在退出时释放

 

解决方法:

Appender 类中增加静态函数:

 

void Appender::destroyAppender()

{

closeAll();

_deleteAllAppenders();

 

delete _allAppenders; 

_allAppenders = NULL;

}

 

 

在 HierarchyMaintainer 类中的 构造函数中加入

 

 

HierarchyMaintainer::HierarchyMaintainer() {

    register_shutdown_handler( Appender::destroyAppender );

    }

 

 

完整的代码及库文件在这里下载:http://download.csdn.net/source/3252558

 

enjoy :)

 

 

 

你可能感兴趣的:(log4cpp 内存泄漏 解决方法)