qt调试日志文件生成

系列文章目录

第一章 qt日志文件生成功能


文章目录


前言

qt有固定的调试日志接口,可以通过终端去打印,但是仅适用在本地去调试,例如想长期放到测试台去检测, 可以采用生成日志文件的方式去监测.

关键字:日志文件


一、qt日志文件生成功能

枚举类型 详情
qDebug 调试信息
qInfo 正常信息
qWarning 警告信息
qCritical 严重错误
qFatal 致命错误

二、使用步骤

qt目录结构

1.代码示例

代码如下(示例):

custommessagehandler.h

cpp 复制代码
#ifndef CUSTOMMESSAGEHANDLER_H
#define CUSTOMMESSAGEHANDLER_H

#include <QtCore>
class CustomMessageHandler
{
public:
    CustomMessageHandler();
    static void customMessageOutput(QtMsgType type, const QMessageLogContext &context, const QString &msg);
};

#endif // CUSTOMMESSAGEHANDLER_H

custommessagehandler.cpp

cpp 复制代码
#include <QFile>
#include <QTextStream>
#include <QDateTime>

#include "custommessagehandler.h"

CustomMessageHandler::CustomMessageHandler()
{

}

void CustomMessageHandler::customMessageOutput(QtMsgType type, const QMessageLogContext &context, const QString &msg)
{
    // 打开文件,确保文件存在并具有写入权限
    //QFile file("D:/work/lmp/qtproject/untitled/logfile.txt");
    QFile file("logfile.txt");
    if (!file.open(QIODevice::Append | QIODevice::Text)) {
        return;
    }

    // 根据消息类型添加前缀
    QString text;
    switch (type) {
    case QtDebugMsg:
        text = QString("Debug: %1").arg(msg);
        break;
    case QtInfoMsg:
        text = QString("Info: %1").arg(msg);
        break;
    case QtWarningMsg:
        text = QString("Warning: %1").arg(msg);
        break;
    case QtCriticalMsg:
        text = QString("Critical: %1").arg(msg);
        break;
    case QtFatalMsg:
        text = QString("Fatal: %1").arg(msg);
        // 注意:QtFatalMsg 会导致应用程序终止,因此这里可能无法写入完整的消息
        break;
    default:
        text = msg;
        break;
    }

    // 写入文件并关闭
    QTextStream out(&file);
    out << QDateTime::currentDateTime().toString("yyyy-MM-dd HH:mm:ss.zzz ") << text << endl;
    file.close();
}

main.cpp

cpp 复制代码
#include "mainwindow.h"
#include <QApplication>
#include "custommessagehandler.h"
#include "QDebug"

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

	// add code start
    // 安装自定义消息处理器
    qInstallMessageHandler(CustomMessageHandler::customMessageOutput);
    qInfo() << "Application started";//输出一般性信息,用于记录应用程序运行过程中的常规信息,帮助开发者了解程序执行流程。
    qDebug() << "Variable value ";//主要用于调试目的,输出详细的调试信息。
    qWarning() << "Invalid input detected, using default value";//输出警告信息,表示程序运行过程中出现了潜在的问题,但并没有阻止程序继续执行
    qCritical() << "Critical failure in network connection";//输出严重错误信息,强调程序发生了严重的、可能会导致程序异常或严重影响程序功能的情况,但程序仍然能够运行并可能有机会尝试恢复。
    // qFatal("Unrecoverable system error occurred");//输出致命错误信息,表示发生了非常严重、无法恢复的错误,通常这类错误会导致程序立即终止
    // ... 你的应用程序代码 ...
	//add code end

    MainWindow w;
    w.show();

    return a.exec();
}

2.运行截图


相关推荐
轻口味44 分钟前
命名空间与模块化概述
开发语言·前端·javascript
晓纪同学2 小时前
QT-简单视觉框架代码
开发语言·qt
威桑2 小时前
Qt SizePolicy详解:minimum 与 minimumExpanding 的区别
开发语言·qt·扩张策略
飞飞-躺着更舒服2 小时前
【QT】实现电子飞行显示器(简易版)
开发语言·qt
fyzy2 小时前
Qt获取本地计算的CPU温度
qt
cbdg37572 小时前
Qt 6 QML Settings location 不创建指定路径文件
qt
了一li2 小时前
Qt中的QProcess与Boost.Interprocess:实现多进程编程
服务器·数据库·qt
杨德杰2 小时前
QT网络(一):主机信息查询
网络·qt
明月看潮生2 小时前
青少年编程与数学 02-004 Go语言Web编程 16课题、并发编程
开发语言·青少年编程·并发编程·编程与数学·goweb
明月看潮生2 小时前
青少年编程与数学 02-004 Go语言Web编程 17课题、静态文件
开发语言·青少年编程·编程与数学·goweb