Qt5實現(xiàn)qDebug日志信息寫入日志文件過程
1、思路
其實Qt提供了將日志寫入文件的方式,是以接口的形式提供的,我們只需要按照我們的需求完成回調函數和我們自己的接口即可。
為方便調用,我們一般直接寫到log.h中即可。
- 1、創(chuàng)建log.h
- 2、根據我們自己的需求完成回調函數
- 3、根據需求封裝外部調用函數并注冊回調函數
2、代碼
我這里按照我的需求,當接口傳遞日志文件名和等級時使用傳遞的文件存儲日志,否則以精確到當前時間為文件名創(chuàng)建日志文件。
提供給外部的調用函數包含日志文件名和日志等級兩個接口,可以不傳遞,直接使用默認值。
Log.h
#ifndef LOG_H#define LOG_H#include <QFile>#include <QTextStream>#include <QDateTime>#include <QMutex>//選擇屏幕打印還是輸出到文件可以根據這個宏控制或者控制函數調用位置都可以//#define _DEBUG//默認調試級別為warning,即小于warning級別的都不會寫入日志文件//只有release版本的時候,才會輸出到日志,debug版本正常輸出到終端。namespace QT_LOG{<!--{C}%3C!%2D%2D%20%2D%2D%3E--> //默認文件名為當前時間命名的log文件 static int m_LogLevel = 1; static QString m_LogFile = QString("%1.log").arg(QDateTime::currentDateTime().toString("yyyyMMddhhmmss")); QMutex m_LogMutex; void customMessageHandler(QtMsgType type , const QMessageLogContext &context , const QString &msg) {<!--{C}%3C!%2D%2D%20%2D%2D%3E--> //設置輸出日志級別,小于該級別,將不會寫入日志文件,默認是warning級別,即debug信息不會寫入日志文件 if (type < m_LogLevel) {<!--{C}%3C!%2D%2D%20%2D%2D%3E--> return; } QString log_info; switch (type) {<!--{C}%3C!%2D%2D%20%2D%2D%3E--> case QtDebugMsg: log_info = QString("%1[Debug]:").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss")); break; case QtWarningMsg: log_info = QString("%1[Warning]:").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss")); break; case QtCriticalMsg: log_info = QString("%1[Critical]:").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss")); break; case QtFatalMsg: log_info = QString("%1[Fatal]:").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss")); abort(); case QtInfoMsg: log_info = QString("%1[Info]:").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss")); break; } log_info += QString(context.file) + QString(context.line) + QString("%1").arg(msg); //為了線程安全 m_LogMutex.lock(); QFile outFile(m_LogFile); outFile.open(QIODevice::WriteOnly | QIODevice::Append | QIODevice::Text); QTextStream ts(&outFile); ts << log_info << endl; outFile.close(); m_LogMutex.unlock(); } //默認調試級別為warning及以上才會寫入日志文件,默認log文件名為程序啟動時間命名的log文件 void logInit(QString logFile = "", int logLevel = 1) {<!--{C}%3C!%2D%2D%20%2D%2D%3E--> #ifndef _DEBUG //實現(xiàn)debug版本的時候,輸出到終端;release版本的時候輸出到日志文件 if ((logLevel < 0) || (logLevel > 3)) {<!--{C}%3C!%2D%2D%20%2D%2D%3E--> m_LogLevel = 1; } else {<!--{C}%3C!%2D%2D%20%2D%2D%3E--> m_LogLevel = logLevel; } if (!logFile.isEmpty()) {<!--{C}%3C!%2D%2D%20%2D%2D%3E--> m_LogFile = logFile; } qInstallMessageHandler(customMessageHandler); #endif }}#endif // LOG_H#ifndef LOG_H #define LOG_H #include <QFile> #include <QTextStream> #include <QDateTime> #include <QMutex> //選擇屏幕打印還是輸出到文件可以根據這個宏控制或者控制函數調用位置都可以 //#define _DEBUG //默認調試級別為warning,即小于warning級別的都不會寫入日志文件 //只有release版本的時候,才會輸出到日志,debug版本正常輸出到終端。 namespace QT_LOG { //默認文件名為當前時間命名的log文件 static int m_LogLevel = 1; static QString m_LogFile = QString("%1.log").arg(QDateTime::currentDateTime().toString("yyyyMMddhhmmss")); QMutex m_LogMutex; void customMessageHandler(QtMsgType type , const QMessageLogContext &context , const QString &msg) { //設置輸出日志級別,小于該級別,將不會寫入日志文件,默認是warning級別,即debug信息不會寫入日志文件 if (type < m_LogLevel) { return; } QString log_info; switch (type) { case QtDebugMsg: log_info = QString("%1[Debug]:").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss")); break; case QtWarningMsg: log_info = QString("%1[Warning]:").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss")); break; case QtCriticalMsg: log_info = QString("%1[Critical]:").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss")); break; case QtFatalMsg: log_info = QString("%1[Fatal]:").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss")); abort(); case QtInfoMsg: log_info = QString("%1[Info]:").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss")); break; } log_info += QString(context.file) + QString(context.line) + QString("%1").arg(msg); //為了線程安全 m_LogMutex.lock(); QFile outFile(m_LogFile); outFile.open(QIODevice::WriteOnly | QIODevice::Append | QIODevice::Text); QTextStream ts(&outFile); ts << log_info << endl; outFile.close(); m_LogMutex.unlock(); } //默認調試級別為warning及以上才會寫入日志文件,默認log文件名為程序啟動時間命名的log文件 void logInit(QString logFile = "", int logLevel = 1) { #ifndef _DEBUG //實現(xiàn)debug版本的時候,輸出到終端;release版本的時候輸出到日志文件 if ((logLevel < 0) || (logLevel > 3)) { m_LogLevel = 1; } else { m_LogLevel = logLevel; } if (!logFile.isEmpty()) { m_LogFile = logFile; } qInstallMessageHandler(customMessageHandler); #endif } } #endif // LOG_H
調用,包含頭文件后直接調用參數即可:
QT_LOG::logInit();//或者QT_LOG::logInit("log.txt", 2);QT_LOG::logInit(); //或者 QT_LOG::logInit("log.txt", 2);
3、問題
可能不通Qt版本提供的回調函數有差異,我們通過qInstallMessageHandler進行源碼查看,看下回調函數的樣式,實現(xiàn)對應的回調函數進行測試即可:
4、結果與擴展思路
這個是我使用我上面封裝的函數后生成的日志文件,每一次啟動創(chuàng)建一個,暫時沒有考慮定時分割創(chuàng)建新文件等問題,如果有需求可以調整回調函數進行調試:
針對上面的日志我們還可以加一些定時任務或者直接通過內存數據庫通過線程安全的方式直接存儲到數據庫中,這樣便于分布式存儲和分析操作日志。
以上就是Qt5實現(xiàn)qDebug日志信息寫入日志文件的詳細內容,更多關于Qt5 qDebug日志信息寫入文件的資料請關注腳本之家其它相關文章!
相關文章
QT Creator+OpenCV實現(xiàn)圖像灰度化的示例代碼
這篇文章主要為大家詳細介紹了QT如何利用Creator和OpenCV實現(xiàn)圖像灰度化效果,文中的示例代碼講解詳細,感興趣的小伙伴可以嘗試一下2022-12-12