qtc++ qdebug日志生成
本文介绍了将qdebug注册到日志系统,这样qdebug打印的信息将记录在日志文本文件,方便观看程序运行中的历史信息,但是需要注意的是,注册后qdebug的信息将不会打印在qtcreator的输出中,所以作者建议,在开发的时候不要注册这个功能,等程序运行上线时加入日志文件
具体实现代码如下
我的写在了main.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();
}
安装消息处理 这行必须有,如果不需要输出到文件,直接将下面这行代码注释即可
qInstallMessageHandler(myMessageOutput);