日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

qt日志

發(fā)布時間:2024/9/27 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 qt日志 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

在程序的運行過程中,debug版的可以調(diào)試,查看輸出信息,release版的程序在運行過程中一旦出現(xiàn)崩潰等問題,使得無法查看問題發(fā)生的點,于是在項目中添加日志,變得極為重要。
此日志可以在程序debug版的時候,不生成日志,直接通過控制臺查看輸出信息,在release版的情況下可以生成日志,供查閱。
具體代碼如下:
log.hpp

#ifndef LOG_H #define LOG_H#include <QCoreApplication> #include <QDebug>//#define OUTPUT_LOG //輸出信息輸出到輸出控制臺還是日志#ifdef OUTPUT_LOG #define outPut qOut//release版 #else #define outPut qDebug()//debug版 #endif//日志文件名稱 #define LOG_FILE QCoreApplication::applicationDirPath()/*strFilePath*/ + "/logger.txt" #define qOut qDebug()<<__FUNCTION__<<"["<<__LINE__<<"]" #define xErrPrint qCritical()<<__FUNCTION__<<"["<<__LINE__<<"]"#endif // LOG_H

在release版的時候打開#define OUTPUT_LOG宏定義的注釋,這樣在release版程序的運行目錄下會生成日志文件,debug版程序可以不用打開#define OUTPUT_LOG的注釋。
main.cpp

#include "maindialog.h"#include <QApplication> #include <QFile> #include "log.hpp" #include <QMutex> #include <QDateTime> #include <QScreen>void MessageTypePut(QtMsgType type, const QMessageLogContext &context, const QString &msg);int main(int argc, char *argv[]) { #ifdef OUTPUT_LOGqInstallMessageHandler(MessageTypePut); #endifQApplication a(argc, argv);QString qss;QString strNameqss;QScreen *screenPrimary=QGuiApplication::primaryScreen();QRect screen =screenPrimary->availableGeometry();if(screen.width() > BASE_W && screen.height() > BASE_H){strNameqss = ":/guangdianadjust.qss";outPut<<"讀取QSS文件guangdianadjust.qss";}else{strNameqss = ":/guangdian.qss";}QFile qssFile(strNameqss);//將qss引入到項目的資源文件,防止運行目錄發(fā)生變化,找不到文件qssFile.open(QFile::ReadOnly);if(qssFile.isOpen()){qss = QString(qssFile.readAll());a.setStyleSheet(qss);qssFile.close();}MainDialog w;w.show();return a.exec(); }void MessageTypePut(QtMsgType type, const QMessageLogContext &context, const QString &msg) { // getCurrFilePath();static QMutex mutex;mutex.lock();QString text;switch(type){case QtDebugMsg:text = QString("Debug:");break;case QtWarningMsg:text = QString("Warning:");break;case QtCriticalMsg:text = QString("Critical:");break;case QtFatalMsg:text = QString("Fatal:");break;default:break;}//日志寫到文件QString current_date_time = QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss");QString message = QString("%1 %2%3").arg(current_date_time).arg(text).arg(msg);QFile file(LOG_FILE);file.open(QIODevice::WriteOnly | QIODevice::Append);QTextStream text_stream(&file);text_stream << message << "\r\n";file.flush();//將緩沖的數(shù)據(jù)刷新到文件file.close();mutex.unlock(); }

在需要日志輸出的地方調(diào)用output輸出,使用方法和qDebug()相似,需要包含頭文件#include “l(fā)og.hpp”。
使用案例:

#include "log.hpp"str = QCoreApplication::applicationDirPath();str += "\\11.png";outPut<<"路徑名:"<<str;

在主函數(shù)中安裝消息句柄,首先聲明這個函數(shù)MessageTypePut,按照這樣就可以實現(xiàn)一個簡單的日志輸出。并在release版的程序生成日志,在debug版直接在輸出臺輸出信息。

總結(jié)

以上是生活随笔為你收集整理的qt日志的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。