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.运行截图


相关推荐
Tttian6221 小时前
Python办公自动化(3)对Excel的操作
开发语言·python·excel
独好紫罗兰2 小时前
洛谷题单2-P5713 【深基3.例5】洛谷团队系统-python-流程图重构
开发语言·python·算法
闪电麦坤953 小时前
C#:base 关键字
开发语言·c#
Mason Lin4 小时前
2025年3月29日(matlab -ss -lti)
开发语言·matlab
DREAM.ZL4 小时前
基于python的电影数据分析及可视化系统
开发语言·python·数据分析
難釋懷4 小时前
JavaScript基础-移动端常见特效
开发语言·前端·javascript
嘤国大力士4 小时前
C++11&QT复习 (七)
java·c++·qt
海姐软件测试4 小时前
Postman参数化设置如何设置?
开发语言·jmeter
松树戈4 小时前
Java常用异步方式总结
java·开发语言
weisian1514 小时前
Java常用工具算法-3--加密算法2--非对称加密算法(RSA常用,ECC,DSA)
java·开发语言·算法