qDebug 消息格式化輸出至文件

簡述

在平時調試時,我們一般選擇用qDebug 打印輸出我們需要的消息,但當程序發佈以後的問題追蹤,qDebug 很明顯不夠用,它的消息輸出以後無法保存,也沒有日期時間,以及日誌輸出位置的標註。這時候就需要我們改造一下它了。先格式化輸出,格式化輸出有兩種方法,先看第一種。

格式化輸出一

自定義一個消息器(其實就是一個回調函數)

#include "stdio.h"
#include "stdlib.h"
#include <QString>
#include <QMessageLogContext>

void myMessageOutput(QtMsgType type, const QMessageLogContext &context, const QString &msg)
{
    QByteArray localMsg = msg.toLocal8Bit();
    switch (type) {
    case QtDebugMsg:
        fprintf(stderr, "Debug: %s (%s:%u, %s)\n", localMsg.constData(), context.file, context.line, context.function);
        break;
    case QtInfoMsg:
        fprintf(stderr, "Info: %s (%s:%u, %s)\n", localMsg.constData(), context.file, context.line, context.function);
        break;
    case QtWarningMsg:
        fprintf(stderr, "Warning: %s (%s:%u, %s)\n", localMsg.constData(), context.file, context.line, context.function);
        break;
    case QtCriticalMsg:
        fprintf(stderr, "Critical: %s (%s:%u, %s)\n", localMsg.constData(), context.file, context.line, context.function);
        break;
    case QtFatalMsg:
        fprintf(stderr, "Fatal: %s (%s:%u, %s)\n", localMsg.constData(), context.file, context.line, context.function);
        abort();
    }
}
  • type: 消息等級,爲 QtMsgType 的枚舉類型變量
  • context: 是一個 QMessageLogContext 類型,裏面包含了文件,行號,函數等信息
  • msg:是一個QString 類型,爲 qDebug 輸出的消息

接下來安裝並測試消息器

安裝消息器

int main(int , char **)
{
    qInstallMessageHandler(myMessageOutput);//安裝消息器
    qDebug("Qt Message"); //打印數據測試消息器
    qWarning("Qt Message");
    qInfo("Qt Message");
    qCritical("Qt Message");
    qInstallMessageHandler(0);//如果不需要消息器了,可以這樣卸載消息器
    return 0;
}

輸出數據

Debug: Qt Message (…\main.cpp:31, int main(int, char**))
Warning: Qt Message (…\main.cpp:32, int main(int, char**))
Info: Qt Message (…\main.cpp:33, int main(int, char**))
Critical: Qt Message (…\main.cpp:34, int main(int, char**))

輸出數據中包含了qDebug 的消息和輸出消息所在文件目錄、行號、函數名。

格式化輸出二

#include <QDebug>

int main(int , char **)
{
    //設置qDebug 輸出格式
    qSetMessagePattern("[%{time yyyy-MM-dd hh:mm:ss ddd} %{file} %{line} %{function}] %{message}");

    qDebug("Qt Message");
    qWarning("Qt Message");
    qInfo("Qt Message");
    qCritical("Qt Message");

    return 0;
}

輸出

[2020-03-21 00:06:14 週六 …\untitled5\main.cpp 32 main] Qt Message
[2020-03-21 00:06:14 週六 …\untitled5\main.cpp 33 main] Qt Message
[2020-03-21 00:06:14 週六 …\untitled5\main.cpp 34 main] Qt Message
[2020-03-21 00:06:14 週六 …\untitled5\main.cpp 35 main] Qt Message

qSetMessagePattern 是Qt 自帶的一個全局函數,利用這個全局函數設置輸出格式,看起來比第一種簡單方便很多。更多格式定義

輸出至文件

#include "stdio.h"
#include "stdlib.h"
#include <QString>
#include <QMessageLogContext>
#include <QFile>

void myMessageOutput(QtMsgType type, const QMessageLogContext &context, const QString &msg)
{
    QString message;
    message = qFormatLogMessage(type, context, msg); //獲取 qSetMessagePattern 設置的格式
    message.append("\r\n");

    QFile file("./log.txt");
    if(file.open(QFile::WriteOnly | QFile::Append)) {
        file.write(message.toLocal8Bit());
    }
    file.close();
}

int main(int , char **)
{
    //設置qDebug 輸出格式
    qSetMessagePattern("[%{time yyyy-MM-dd hh:mm:ss ddd} %{file} %{line} %{function}] %{message}");
    //安裝消息器
    qInstallMessageHandler(myMessageOutput);

    qDebug("Qt Message");
    qWarning("Qt Message");
    qInfo("Qt Message");
    qCritical("Qt Message");

    return 0;
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章