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

猜你喜欢

转载自wenxiehao.iteye.com/blog/1572111