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


相关推荐
крон1 小时前
【Auto.js例程】华为备忘录导出到其他手机
开发语言·javascript·智能手机
zh_xuan2 小时前
c++ 单例模式
开发语言·c++·单例模式
老胖闲聊2 小时前
Python Copilot【代码辅助工具】 简介
开发语言·python·copilot
Blossom.1182 小时前
使用Python和Scikit-Learn实现机器学习模型调优
开发语言·人工智能·python·深度学习·目标检测·机器学习·scikit-learn
曹勖之3 小时前
基于ROS2,撰写python脚本,根据给定的舵-桨动力学模型实现动力学更新
开发语言·python·机器人·ros2
豆沙沙包?3 小时前
2025年- H77-Lc185--45.跳跃游戏II(贪心)--Java版
java·开发语言·游戏
军训猫猫头4 小时前
96.如何使用C#实现串口发送? C#例子
开发语言·c#
liuyang-neu4 小时前
java内存模型JMM
java·开发语言
我很好我还能学5 小时前
【面试篇 9】c++生成可执行文件的四个步骤、悬挂指针、define和const区别、c++定义和声明、将引用作为返回值的好处、类的四个缺省函数
开发语言·c++
蓝婷儿6 小时前
6个月Python学习计划 Day 16 - 面向对象编程(OOP)基础
开发语言·python·学习