qt 打印日志

在 Qt Creator 中,将 QDebug、QInfo、QWarning、QCritical 和 QFatal 打印的日志输出到指定文件,需要设置 Qt 的消息处理机制。这通常涉及到安装一个自定义的消息处理器,该处理器将日志消息重定向到文件。以下是一个基本的步骤指南:

创建一个自定义消息处理器类

首先,需要创建一个继承自 QtMessageHandler 的类。这个类将重写 QtMessageHandler 的 message 函数,以便将日志消息写入文件。

CustomMessageHandler.h

复制代码
// CustomMessageHandler.h  
#ifndef CUSTOMMESSAGEHANDLER_H  
#define CUSTOMMESSAGEHANDLER_H  
  
#include <QtCore>  
  
class CustomMessageHandler  
{  
public:  
    static void customMessageOutput(QtMsgType type, const QMessageLogContext &context, const QString &msg);  
};  
  
#endif // CUSTOMMESSAGEHANDLER_H

然后,在 .cpp 文件中,将包含这个头文件,并实现静态函数 customMessageOutput

复制代码
// CustomMessageHandler.cpp  
#include "CustomMessageHandler.h"  
#include <QFile>  
#include <QTextStream>  
#include <QDateTime>  
  
void CustomMessageHandler::customMessageOutput(QtMsgType type, const QMessageLogContext &context, const QString &msg)  
{  
    // 打开文件,确保文件存在并具有写入权限  
    QFile file("path/to/your/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 文件中,需要在 main 函数开始处安装这个自定义消息处理器:

复制代码
#include <QCoreApplication>  
#include "CustomMessageHandler.h"  
  
int main(int argc, char *argv[])  
{  
    QCoreApplication a(argc, argv);  
  
    // 安装自定义消息处理器  
    qInstallMessageHandler(CustomMessageHandler::customMessageOutput);  
   // 安装自定义消息处理器
    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");//输出致命错误信息,表示发生了非常严重、无法恢复的错误,通常这类错误会导致程序立即终止
    // ... 你的应用程序代码 ...  
  
    return a.exec();  
}

结果查看:

相关推荐
萌新小码农‍11 分钟前
python装饰器
开发语言·前端·python
KK溜了溜了14 分钟前
Python从入门到精通
服务器·开发语言·python
故事和你9129 分钟前
洛谷-【图论2-1】树5
开发语言·数据结构·c++·算法·动态规划·图论
threelab34 分钟前
Three.js 初中数学函数可视化 | 三维可视化 / AI 提示词
开发语言·前端·javascript·人工智能·3d·着色器
xiaoshuaishuai81 小时前
C# CDN加速与离线包优化PowerSetting慢问题
开发语言·windows·spring·c#
凉辰1 小时前
解决 H5 键盘遮挡与页面上推
开发语言·javascript·计算机外设
计算机安禾2 小时前
【c++面向对象编程】第25篇:仿函数(函数对象):重载operator()
开发语言·c++·算法
Rust语言中文社区2 小时前
【Rust日报】2026-05-14 Pyrefly v1.0 正式发布:快速的 Python 类型检查器和语言服务器
开发语言·后端·python·rust
kkeeper~2 小时前
0基础C语言积跬步之深入理解指针(4)
c语言·开发语言
周末也要写八哥2 小时前
在C++中使用预定义宏
开发语言·c++·算法