qt5添加日志文件

为了方便调试,可以在程序中添加一定的打印信息,这样可以通过串口打印进行查看,

但是这种方式只适合开发阶段中的开发人员,对于测试人员可能不会接串口来查看程序

运行过程中的打印信息。这时我们可以将打印信息以文本的形式保存起来,方便出问题

时查看打印日志,对已QT可以很方便实现。代码实现如下:

#ifdef DEBUG_LOG

void customMessageHandler(QtMsgType type, const QMessageLogContext &ctx, const QString &msg)
{
    QString txt;
    QDateTime time = QDateTime::currentDateTime();
    QString timeStr = time.toString("yyyy-MM-dd hh:mm:ss");


    switch (type)
    {
        case QtDebugMsg:
            txt = QString("Debug:(%1) <%2> [%3] {%4}").arg(timeStr).arg(ctx.file).arg(ctx.line).arg(msg);
            break;
        case QtWarningMsg:
            txt = QString("Warning:(%1) <%2> [%3] {%4}").arg(timeStr).arg(ctx.file).arg(ctx.line).arg(msg);
            break;
        case QtCriticalMsg:
            txt = QString("Critical:(%1) <%2> [%3] {%4}").arg(timeStr).arg(ctx.file).arg(ctx.line).arg(msg);
            break;
        case QtFatalMsg:
            txt = QString("Fatal:(%1) <%2> [%3] {%4}").arg(timeStr).arg(ctx.file).arg(ctx.line).arg(msg);
            break;
        default:
            break;

    }
#ifdef RUN_ON_PC
    QFile outFile("/home/firephoenix/work/yuv/debugLog.txt");
#else
    QFile outFile("/mnt/sdcard/mmcblk1p1/video/debugLog.txt");
#endif
    outFile.open(QIODevice::WriteOnly | QIODevice::Append);
    QTextStream ts(&outFile);
    ts << txt << endl;
}

#endif

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);

#ifdef DEBUG_LOG
    qInstallMessageHandler(customMessageHandler);
#endif

    WinFrame w;
    w.show();

    return a.exec();
}

为了方便开发与测试阶段都能方便的查看调试信息,可以在.pro文件中定义

DEFINES += DEBUG_LOG

这样在开发阶段可以将其屏蔽,这样开发人员可以通过串口查看打印信息,发行测试版本时可以将屏蔽

去掉,这样在测试阶段的打印信息将会保存在文件中。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值