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.youkuaiyun.com/source/3252558
  enjoy :)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值