以前一直自己写日志类的框架
最近了解了一下开源的,感觉功能很强大!呵呵
使用了老牌的log4cpp 竟然发现有内存泄漏的问题,大概读了一下代码,并找到了这个问题。现放出来让大家也了解下
感觉这可能是编程习惯问题,如果程序退出时,有些人觉得对象就没必要删除了,因为,整个程序已经退出了,系统会处理一些事情(哪些事情?)
但是,到了MFC下面,退出时出现这些提示,让人感觉非常不爽!
内存问题一共三个地方:
1.NDC
对于不同的线程,有不同的数据需要保存,退出时自然需要释放。
解决方法,增加一个静态的函数
NDC.h
void NDC::clearCurrentThreadNDC()
{
_nDC.reset();
}
在所有用过日志的线程里,最后退出时,加上调用此函数的代码。
2. template<typename T> 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 :)