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);
相关推荐
鲸屿1951 小时前
python之socket网络编程
开发语言·网络·python
没有梦想的咸鱼185-1037-16631 小时前
基于R语言机器学习方法在生态经济学领域中的实践技术应用
开发语言·机器学习·数据分析·r语言
向上的车轮2 小时前
基于go语言的云原生TodoList Demo 项目,验证云原生核心特性
开发语言·云原生·golang
The Chosen One9852 小时前
C++ : AVL树-详解
开发语言·c++
zzyzxb2 小时前
std::enable_shared_from_this
c++
SNAKEpc121382 小时前
QML和Qt Quick
c++·qt
PH_modest2 小时前
【Qt跬步积累】—— 初识Qt
开发语言·qt
hansang_IR2 小时前
【题解】洛谷 P4286 [SHOI2008] 安全的航线 [递归分治]
c++·数学·算法·dfs·题解·向量·点积
GanGuaGua2 小时前
Linux系统:线程的互斥和安全
linux·运维·服务器·c语言·c++·安全
怀旧,2 小时前
【C++】18. 红⿊树实现
开发语言·c++