在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,不理解。。。