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);
相关推荐
栈与堆10 分钟前
LeetCode 19 - 删除链表的倒数第N个节点
java·开发语言·数据结构·python·算法·leetcode·链表
一路向北·重庆分伦12 分钟前
03-01:MQ常见问题梳理
java·开发语言
txinyu的博客17 分钟前
结合游戏场景理解,互斥锁,读写锁,自旋锁,CAS / 原子变量,分段锁
开发语言·c++·游戏
hugerat22 分钟前
在AI的帮助下,用C++构造微型http server
linux·c++·人工智能·http·嵌入式·嵌入式linux
阿里嘎多学长25 分钟前
2026-01-11 GitHub 热点项目精选
开发语言·程序员·github·代码托管
yuanyikangkang25 分钟前
STM32 lin控制盒
开发语言
-森屿安年-27 分钟前
unordered_map 和 unordered_set 的实现
数据结构·c++·散列表
九久。1 小时前
手动实现std:iterator/std:string/std::vector/std::list/std::map/std:set
c++·stl
小羊羊Python1 小时前
Sound Maze - 基于 SFML+C++14 的音效迷宫开源游戏 | MIT 协议
c++·游戏·开源