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);
相关推荐
2601_961845155 分钟前
2026法考资料pdf|电子版|资料已整理
开发语言·前端框架·pdf·c#·xhtml·csrf·view design
何以解忧,唯有..6 分钟前
Go 语言数据类型详解:从基础到复合类型
开发语言·golang·mfc
Mortalbreeze8 分钟前
C++ Lambda表达式详解:从捕获列表到底层原理
开发语言·c++
为何创造硅基生物13 分钟前
LVGL
c++·ui
MATLAB代码顾问14 分钟前
Python NumPy数值计算核心指南
开发语言·python·numpy
只做人间不老仙20 分钟前
C++ grpc 拦截器示例学习
开发语言·c++·学习
踏着七彩祥云的小丑21 分钟前
Go学习第7天:Map集合 + 递归函数 + 类型转换
开发语言·学习·golang·go
何以解忧,唯有..23 分钟前
Go语言变量的声明方式详解
开发语言·后端·golang
半夜燃烧的香烟30 分钟前
springboot3.0 集成minio上传文件,支持多个桶名
java·开发语言·spring boot
不会C语言的男孩31 分钟前
Linux 系统编程 · 第 1 章:Linux 系统概述
c语言·开发语言