在Qt中使用日志

在Qt中使用日志

Qt提供了5个全局函数用于输出调试或警告信息。

  • qDebug:调试信息
  • qWarning:警告信息
  • qCritical:严重错误
  • qFatal:致命错误
  • qInfo : 正常信息

这次我们要调用qInstallMessageHandler()函数注册自己的消息处理器,替换Qt框架的默认消息处理器

1.创建logFile类,参看头文件,源文件截图

0_1522504327994_TIM截图20180331214844.png
0_1522504288813_TIM截图20180331215031.png

2.在main函数使用logFile类

0_1522504423055_TIM截图20180331214844.png

3.qml测试输出log,因为qml没有console.fatel,我用error代替了

0_1522504632327_TIM截图20180331214844.png

4.测试结果

0_1522504808913_TIM截图20180331214844.png

5.总结,qml与日志类对应关系

qml logFile
debug,log QtDebugMsg
warn QtWarningMsg
error QtCriticalMsg
info QtInfoMsg
? QtFatalMsg

6.接下来,测试c++方面,头文件,源文件如下

0_1522505287790_TIM截图20180331214844.png
0_1522505414360_TIM截图20180331214844.png

7.将类注册到qml使用

0_1522505507882_TIM截图20180331214844.png
0_1522505601865_TIM截图20180331221306.png
0_1522505619590_TIM截图20180331214844.png

8.qml输出log与调用qt输出log对比

0_1522505754821_TIM截图20180331214844.png

9.总结,qt原生log与日志类对应关系,一一对应

qt logFile
QtDebugMsgTest QtDebugMsg
QtWarningMsgTest QtWarningMsg
QtCriticalMsgTest QtCriticalMsg
QtInfoMsgTest QtInfoMsg
QtFatalMsgTest QtFatalMsg

10.PS: 有个让人郁闷的事情,调用日志类的fatal,程序不会崩溃,调用qt原生的qFatal,程序会崩溃,不知道为啥。。
还有调用qt输出的log,没有文件名和行数和函数入口,都是null,0,不理解。。。

你可能感兴趣的:(在Qt中使用日志)