实现功能: 将调试信息打印到文本,记录详细日志信息(包括产生时间、等级、所在文件、所在行号、描述信息、),以便于快速跟踪、定位。控制日志文件数量,减少日志文件对存储空间的占用。
参考qt助手:qInstalMessageHandler
Qtt包含用于警告和调试文本的全局宏:
qDebug() 调试消息
qInfo() 信息消息
qWarning() 警告消息和可恢复的错误
qCritical() 关键错误和系统错误
qFatal() 致命错误
#include <qapplication.h> #include <stdio.h> #include <stdlib.h> void myMessageOutput(QtMsgType type, const QMessageLogContext &context, const QString &msg) { QByteArray localMsg = msg.toLocal8Bit(); switch (type) { case QtDebugMsg: fprintf(stderr, "Debug: %s (%s:%u, %s)\n", localMsg.constData(), context.file, context.line, context.function); break; case QtInfoMsg: fprintf(stderr, "Info: %s (%s:%u, %s)\n", localMsg.constData(), context.file, context.line, context.function); break; case QtWarningMsg: fprintf(stderr, "Warning: %s (%s:%u, %s)\n", localMsg.constData(), context.file, context.line, context.function); break; case QtCriticalMsg: fprintf(stderr, "Critical: %s (%s:%u, %s)\n", localMsg.constData(), context.file, context.line, context.function); break; case QtFatalMsg: fprintf(stderr, "Fatal: %s (%s:%u, %s)\n", localMsg.constData(), context.file, context.line, context.function); abort(); } } int main(int argc, char **argv) { qInstallMessageHandler(myMessageOutput);//register QApplication app(argc, argv); ... return app.exec(); } release 版本在Pro文件添加