log4cpp 内存泄漏 解决方法

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

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

 

使用了老牌的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 :)

 

 

 

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值