在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


Log in to reply
 

走马观花

最近的回复

  • 如果对操作不是很熟悉或者是操作不便的话,也可以在Windows的命令行执行NDK的安装。参数是一样的:
    Windows命令行安装NDK

    read more
  • 忘记补充图片了。这里需要点击更新安装才行。😆
    点击更新安装

    read more
  • 问:
    如何在Qt Creator安装NDK呢?
    除了那个🔽 按钮外,还有别的办法吗?
    答:
    Qt Creaator 4.11中更加整合了Android SDK Manager。其实大家都可以不运行默认的Android SDK Manager,直接在Qt Creator中选项->设备->Android,就可以进行操作了。

    通过````高级选项……,启动一些Android SDK Manager,只需要带上参数ndk-bundle```。原来没有NDK的你,也可以通过Android SDK Manager安装了。很简单吧。
    Android SDK Manager安装NDK

    read more
  • 挺好的分享,谢谢。1515759557.jpg

    read more

关注我们

微博
QQ群