qdebug重定向_如何重定向qDebug,qWarning,qCritical等输出?

这里是一个跨平台的解决方案,以登录到控制台,如果应用程序是从Qt Creator的和到debug.log文件运行,当它被编译并正在跑作为独立的应用程序。

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 = formattedTime.toLocal8Bit();

QString logLevelName = msgLevelHash[type];

QByteArray logLevelMsg = logLevelName.toLocal8Bit();

if (logToFile) {

QString txt = QString("%1 %2: %3 (%4)").arg(formattedTime, logLevelName, msg, context.file);

QFile outFile(logFilePath);

outFile.open(QIODevice::WriteOnly | QIODevice::Append);

QTextStream ts(&outFile);

ts << txt << endl;

outFile.close();

} else {

fprintf(stderr, "%s %s: %s (%s:%u, %s)\n", formattedTimeMsg.constData(), logLevelMsg.constData(), localMsg.constData(), context.file, context.line, context.function);

fflush(stderr);

}

if (type == QtFatalMsg)

abort();

}

int main(int argc, char *argv[])

{

QByteArray envVar = qgetenv("QTDIR"); // check if the app is ran in Qt Creator

if (envVar.isEmpty())

logToFile = true;

qInstallMessageHandler(customMessageOutput); // custom message handler for debugging

QApplication a(argc, argv);

// ...and the rest of 'main' follows

日志格式由QString("%1 %2: %3 (%4)").arg...处理(用于文件)和fprintf(stderr, "%s %s: %s (%s:%u, %s)\n"...(控制台)。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值