Qt 日志信息输出到文本和控制台

匿名 (未验证) 提交于 2019-12-03 00:34:01

实现功能: 将调试信息打印到文本,记录详细日志信息(包括产生时间、等级、所在文件、所在行号、描述信息、),以便于快速跟踪、定位。控制日志文件数量,减少日志文件对存储空间的占用。

参考qt助手:qInstalMessageHandler

Qtt包含用于警告和调试文本的全局宏:

  • qDebug() 调试消息

  • 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.int main(int argc, char **QApplication app(argc, argv);     ...     return app.exec(); } release 版本在Pro文件添加  


易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!