QT学习 自定义消息处理程序

本文介绍了如何利用Qt的qInstallMessageHandler函数自定义消息处理器,将错误信息分别输出到文件作为日志记录和控制台显示,通过不同类型的处理函数实现Debug、Warning等消息的差异化输出。

利用函数qInstallMessageHandler

自定义消息处理函数原型

void QtMessageHandler(QtMsgType type, const QMessageLogContext &context, const QString &msg)

  • Type
  1. QtDebugMsg 对应 qDebug
  2. QtWarningMsg 对应 qWarning
  3. QtCriticalMsg 对应 qCritical
  4. QtFatalMsg 对应 qFatal
  5. QtInfoMsg 对应 qInfo
  • Context 保存了消息输出时的上下文信息,包括所处文件,所处行号,所处函数
  • msg 是用户消息字符串。

当重定向之后,控制台或QT的输出窗口就不再显示信息了

取消重定向,使用qInstallMessageHandler(0)

在这个自定义的消息处理函数中编写输出方式,以及输出的附加内容

比如,利用Qfile可以把消息内容输出到文件,可作为日志

比如,利用fprintf(stderr,则把消息内容输出到控制台或QT的输出窗口

例如

void MyMessageOut(QtMsgType type, const QMessageLogContext &context, const QString &msg)
{
    m_mutex.lock();
 
    QByteArray localMsg = msg.toLocal8Bit();
    QString strMsg("");
 
    switch(type)
    {
    case QtDebugMsg:
        strMsg = QString("Debug");
        break;
  
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值