qdebug重定向_c ++ - 如何重定向qDebug,qWarning,qCritical等输出?

这篇博客介绍了如何在Qt应用中实现跨平台的日志重定向,当在Qt Creator中运行时输出到控制台,而作为独立应用运行时将qDebug、qWarning、qCritical等输出记录到debug.log文件。主要通过自定义messageHandler `customMessageOutput` 实现,根据环境变量判断是否启用日志文件,并采用不同格式记录日志。
摘要由CSDN通过智能技术生成

这是一个跨平台解决方案,用于登录控制台,如果应用程序是从Qt Creator运行到QString("%1 %2: %3 (%4)").arg...文件,当它被编译并作为独立应用程序运行时。

main.cpp中:

#include

#include

#include

#include

#include

#include

#include

#include

const QString logFilePath = "debug.log";

bool logToFile = false;

void customMessageOutput(QtMsgType type, const QMessageLogContext &context, const QString &msg)

{

QHash msgLevelHash({ {QtDebugMsg, "Debug"}, {QtInfoMsg, "Info"}, {QtWarningMsg, "Warning"}, {QtCriticalMsg, "Critical"}, {QtFatalMsg, "Fatal"}});

QByteArray localMsg = msg.toLocal8Bit();

QTime time = QTime::currentTime();

QString formattedTime = time.toString("hh:mm:ss.zzz");

QByteArray formattedTimeMsg = formatte

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值