qml打印输出行号

24 篇文章 1 订阅

在qml中我们调试打印信息使用console.log()方式去打印信息,但是在控制台上并不能显示该条信息具体打印的位置以及是哪个文件。如果我们项目的文件非常多,那么很难定位。那么使用Qt日志重定向功能很好的解决这个问题。

1.在main.cpp中加入以下代码:

#include <QFile>
#include <QMutex>
#include <QDateTime>

QtMessageHandler gDefaultHandler = NULL;
void myMessageOutput(QtMsgType type, const QMessageLogContext &context, const QString &msg)
{
    QDateTime time = QDateTime::currentDateTime();
    QString strTime = time.toString("MM-dd hh:mm:ss");
    QString strMessage = QString("[%1 File:%2  Line:%3  Function:%4]:  %5")
            .arg(strTime).arg(context.file).arg(context.line).arg(context.function).arg(msg);

    QString strMsg("");
    switch(type)
    {
    case QtDebugMsg:
        strMsg = QString("Debug");
        break;
    case QtInfoMsg:
        strMsg = QString("Info");
        break;
    case QtWarningMsg:
        strMsg = QString("Warning:");
        break;
    case QtCriticalMsg:
        strMsg = QString("Critical:");
        break;
    case QtFatalMsg:
        strMsg = QString("Fatal:");
        break;
    default:
        strMsg = QString("Err");
        break;
    }

    strMessage = strMsg+strMessage;

#if 0
    // 加锁
    static QMutex mutex;
    mutex.lock();


    // 输出信息至文件中(读写、追加形式)
    QFile file("D:\\log.txt");
    file.open(QIODevice::ReadWrite | QIODevice::Append);
    QTextStream stream(&file);
    stream << strMessage << "\r\n";
    file.flush();
    file.close();

    // 解锁
    mutex.unlock();
#endif
    //用系统原来的函数完成原来的功能. 比如输出到调试窗
    if(gDefaultHandler)
    {
        gDefaultHandler(type,context,strMessage);
    }

}

2.在main函数中调用:

gDefaultHandler = qInstallMessageHandler(myMessageOutput);

这样不论是qml还是cpp文件的打印,都可以输出你想要的信息。

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Liu-Eleven

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值