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


相关推荐
极客代码2 分钟前
【Python TensorFlow】进阶指南(续篇三)
开发语言·人工智能·python·深度学习·tensorflow
土豆湿8 分钟前
拥抱极简主义前端开发:NoCss.js 引领无 CSS 编程潮流
开发语言·javascript·css
界面开发小八哥15 分钟前
更高效的Java 23开发,IntelliJ IDEA助力全面升级
java·开发语言·ide·intellij-idea·开发工具
qystca44 分钟前
洛谷 B3637 最长上升子序列 C语言 记忆化搜索->‘正序‘dp
c语言·开发语言·算法
薯条不要番茄酱44 分钟前
数据结构-8.Java. 七大排序算法(中篇)
java·开发语言·数据结构·后端·算法·排序算法·intellij-idea
今天吃饺子1 小时前
2024年SCI一区最新改进优化算法——四参数自适应生长优化器,MATLAB代码免费获取...
开发语言·算法·matlab
努力进修1 小时前
“探索Java List的无限可能:从基础到高级应用“
java·开发语言·list
Ajiang28247353043 小时前
对于C++中stack和queue的认识以及priority_queue的模拟实现
开发语言·c++
幽兰的天空3 小时前
Python 中的模式匹配:深入了解 match 语句
开发语言·python
Theodore_10226 小时前
4 设计模式原则之接口隔离原则
java·开发语言·设计模式·java-ee·接口隔离原则·javaee