Qt 之 qInstallMessageHandler(输出详细日志)

作者: 一去、二三里
个人微信号: iwaleon
微信公众号: 高效程序员

安装之前已定义的消息处理程序,返回一个指向前一个消息处理程序。

消息处理程序是一个函数,用于打印调试信息、警告信息、严重错误和致命的错误的消息。Qt库(debug模式)包含成百上千的警告信息打印,当发生内部错误时(通常是无效的函数参数)。Qt在release模式下构建还包含这些警告,除非在编译时设置QT_NO_WARNING_OUTPUT和/或QT_NO_DEBUG_OUTPUT。如果你实现自己的消息处理程序,就可以完全控制这些消息。

缺省的消息处理程序向标准输出打印消息。如果是一个致命的消息,应用程序就会立即中止。

仅可以定义一个消息处理程序,因为这通常是在应用范围的基础上进行的,以控制调试输出。

调用qInstallMessageHandler(0)可以恢复消息处理程序。

调试级别

Q包含用于警告和调试文本的全局宏:

  • qDebug()
    调试消息

  • qInfo()
    信息消息

  • qWarning()
    警告消息和可恢复的错误

  • qCritical()
    关键错误和系统错误

  • qFatal()
    致命错误

如果包含头文件<QDebug>,就可以将所述qDebug()宏用作一个输出流。

例如:

qDebug() << "Widget" << widget << "at position" << widget->pos();

Windows中,如果是一个控制台应用程序,文本将被发送到控制台;否则,被发送到调试器。

正常使用

一般情况下,在调试程序的时候,我们会输出一些调试信息,便于程序跟踪。

例如:

int main(int argc, char **argv)
{
    QApplication app(argc, argv);

	// 打印信息
    qDebug("This is a debug message.");
    qWarning("This is a warning message.");
    qCritical("This is a critical message.");
    qFatal("This is a fatal message.");
    
    ...
    return app.exec();
}

输出如下:

This is a debug message.
This is a warning message.
This is a critical message.
This is a fatal message.

自定义消息处理

一般情况下,一个大型项目会出现很多这样类似的调试信息,很不利于查找,因为我们根本不清楚输出信息所在的文件、函数、行号等信息。

下面,我们来根据需要自定义消息处理程序。

#include <QApplication>
#include <stdio.h>
#include <stdlib.h>

// 自定义消息处理程序
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();
    }
}

int main(int argc, char **argv)
{
    QApplication app(argc, argv);
    
    // 安装消息处理程序
	qInstallMessageHandler(myMessageOutput);
	
	// 打印信息
    qDebug("This is a debug message.");
    qWarning("This is a warning message.");
    qCritical("This is a critical message.");
    qFatal("This is a fatal message.");
    
    ...
    return app.exec();
}

这时,我们不仅可以输出调试信息,而且可以很直观、很方便的得到输出代码所在的文件、函数、行号等信息。

输出如下:

Debug: This is a debug message. (…\MessageOutput\main.cpp:90, int __cdecl main(int,char *[]))
Warning: This is a warning message. (…\MessageOutput\main.cpp:91, int __cdecl main(int,char *[]))
Critical: This is a critical message. (…\MessageOutput\main.cpp:92, int __cdecl main(int,char *[]))
Fatal: This is a fatal message. (…\MessageOutput\main.cpp:93, int __cdecl main(int,char *[]))

更多参考

  • 17
    点赞
  • 91
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 10
    评论
要将Qt的工作台输出改到Qt界面输出,可以使用QTextEdit控件来显示输出信息。首先,需要在主窗口类中创建一个QTextEdit对象,用于显示输出信息。然后,使用qInstallMessageHandler函数来自定义消息处理流程,将输出信息重定向到QTextEdit控件中。 在主窗口类的构造函数中,创建一个QTextEdit对象,并设置其属性和大小。然后,使用qInstallMessageHandler函数来设置自定义的消息处理函数。在消息处理函数中,将输出信息追加到QTextEdit控件中。 以下是示例代码: ```cpp // 在主窗口类中定义一个QTextEdit对象 QTextEdit *debugEdit; // 自定义消息处理函数 void outputMessage(QtMsgType type, const QMessageLogContext &context, const QString &msg) { // 根据消息类型设置输出格式 QString output; switch (type) { case QtDebugMsg: output = QString("Debug: %1").arg(msg); break; case QtWarningMsg: output = QString("Warning: %1").arg(msg); break; case QtCriticalMsg: output = QString("Critical: %1").arg(msg); break; case QtFatalMsg: output = QString("Fatal: %1").arg(msg); break; default: break; } // 将输出信息追加到QTextEdit控件中 debugEdit->append(output); } // 在主窗口类的构造函数中设置QTextEdit控件和消息处理函数 MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent) { // 创建QTextEdit对象 debugEdit = new QTextEdit(); debugEdit->setWindowTitle("调试窗口"); debugEdit->resize(500, 300); debugEdit->setAttribute(Qt::WA_QuitOnClose, false); debugEdit->hide(); // 设置自定义的消息处理函数 qInstallMessageHandler(outputMessage); } ``` 通过以上代码,你可以将Qt的工作台输出改到Qt界面输出,将输出信息显示在QTextEdit控件中。 #### 引用[.reference_title] - *1* *3* [QT 日志输出控制台、控件、文件](https://blog.csdn.net/weixin_49569127/article/details/123201370)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [QT 学习笔记(六)](https://blog.csdn.net/weixin_45891612/article/details/128087543)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一去丶二三里

有收获,再打赏!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值