log4cplus导致主进程不能退出问题解决
log4cplus::Initializer
構造函數調用log4cplus::initialize(),析構函數調用log4cplus::Logger::shutdown()
log4cplus::Initializer m_initializer;//構造函數調用log4cplus::initialize(),析構函數調用log4cplus::Logger::shutdown()
還沒完:當你使用了ThreadPool之后,log4cplus總是會在main函數執行之前使用static機制初始化,并創建線程池。如果你在main函數退出的時候沒有調用
log4cplus::deinitialize();
則線程池中的線程不會退出。導致main函數無法退出。所以要在main函數退出之前調用這句話,如果不調用,那個log4cplus::Initializer m_initializer;只負責調用shutdown,而不負責調用clearThreadPool。只有log4cplus::deinitialize();才會既clearThreadPool又shutdown。
可以單獨封裝一個接口,類似如下:
void close() {log4cplus::deinitialize(); }然后在主程序main函數return之前調用該函數即可,如下為Qt程序下的main函數:
int main(int argc, char *argv[]) {QApplication a(argc, argv);.............. // 應用程序其它代碼.............. // 應用程序其它代碼.............. // 應用程序其它代碼int k = a.exec();close(); // 讓日志庫log4cplus中的線程池等資源退出,否則即使main退出了,但主進程依然不會退出return k; }非常詳細介紹log4cplus的博客:
https://blog.csdn.net/lx_shudong/article/details/48732999
?
總結
以上是生活随笔為你收集整理的log4cplus导致主进程不能退出问题解决的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: JS代码查看浏览器页面放大比例
- 下一篇: win10系统一键备份的方法是什么