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



  • 不过,日志类最好要大写哦。
    其它的还是很棒的啦。
    给你点个赞。
    0_1522504798320_美丽的.jpg



  • @梦广 logfile,这么写吗



  • 不是的呢,而是LogFile这样写的类。



  • @青山白云 虽然用C语言的File比较轻量,但是也要注意的是跨平台的兼容性。最好也使用Qt的类会好一些吧。
    0_1522505090750_人人人人.jpg


 

走马观花

最近的回复

关注我们

微博
QQ群











召唤伊斯特瓦尔