失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > qDebug 消息格式化输出至文件

qDebug 消息格式化输出至文件

时间:2023-12-12 07:41:57

相关推荐

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;}

输出

[-03-21 00:06:14 周六 …\untitled5\main.cpp 32 main] Qt Message

[-03-21 00:06:14 周六 …\untitled5\main.cpp 33 main] Qt Message

[-03-21 00:06:14 周六 …\untitled5\main.cpp 34 main] Qt Message

[-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;}

如果觉得《qDebug 消息格式化输出至文件》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。
相关阅读
QDebug 输出调试信息

QDebug 输出调试信息

2023-05-28

qDebug输出QString

qDebug输出QString

2022-02-14

qDebug 输出中文

qDebug 输出中文

2020-01-28

Qt qDebug()输出操作

Qt qDebug()输出操作

2019-11-01