qtc++ qdebug日志生成

本文介绍了将qdebug注册到日志系统,这样qdebug打印的信息将记录在日志文本文件,方便观看程序运行中的历史信息,但是需要注意的是,注册后qdebug的信息将不会打印在qtcreator的输出中,所以作者建议,在开发的时候不要注册这个功能,等程序运行上线时加入日志文件

具体实现代码如下

我的写在了main.cpp中

cpp 复制代码
// 重定向 qDebug 输出到文件
void myMessageOutput(QtMsgType type, const QMessageLogContext &context, const QString &msg)
{

    QFile outFile("log.txt");
    outFile.open(QIODevice::WriteOnly | QIODevice::Append);
    QTextStream ts(&outFile);
    ts << QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss.zzz ") << msg;
    switch (type) {
    case QtDebugMsg:
        ts << "Debug: ";
        break;
    case QtInfoMsg:
        ts << "Info: ";
        break;
    case QtWarningMsg:
        ts << "Warning: ";
        break;
    case QtCriticalMsg:
        ts << "Critical: ";
        break;
    case QtFatalMsg:
        ts << "Fatal: ";
        break;
    }

    ts << "[" << context.file << ":" << context.line << " " << context.function << "] " << msg << "\n";
    ts.flush(); // 确保及时写入
    outFile.close();
}

安装消息处理 这行必须有,如果不需要输出到文件,直接将下面这行代码注释即可

cpp 复制代码
qInstallMessageHandler(myMessageOutput);
相关推荐
烤麻辣烫3 分钟前
黑马程序员苍穹外卖(新手)DAY8
java·开发语言·学习·spring·intellij-idea
就叫飞六吧4 分钟前
Java 中编译一个 java 源文件产生多个 .class 文件原因
java·开发语言
IMPYLH7 分钟前
Lua 的 rawset 函数
开发语言·笔记·单元测试·lua
python零基础入门小白11 分钟前
2025年大模型面试通关秘籍!大厂高频LLMs真题全解析,一文掌握,助你轻松斩获心仪offer!
开发语言·人工智能·语言模型·架构·langchain·大模型教程·大模型面试
chenyuhao202419 分钟前
MySQL事务
开发语言·数据库·c++·后端·mysql
爪哇部落算法小助手22 分钟前
每日两题day59
数据结构·c++·算法
g***789122 分钟前
Java语法进阶
java·开发语言·jvm
D_evil__30 分钟前
[C++高频精进] 现代C++特性:右值引用和移动语义
c++
白露与泡影31 分钟前
Java面试题2025最新、最全、最细(附答案)
java·开发语言
幸运小圣37 分钟前
递归(Recursion)快速上手指南【JS例子】
开发语言·javascript·ecmascript