在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


 

走马观花

最近的回复

  • @chinasmu Webkit网络的部分可能不是受到Qt控制的,扩展性较差,所以呢,还不能通过代码的方式侦听网络收发数据。但是WebEngine就可以。如果可以的话,试试Qt WebEngine。😺

    阅读更多
  • C

    我用qt建了个对话框程序,里面加了个webkit,请问有办法获取该控件的全部网络封包通信数据吗?
    不采用windows hook recv和send函数的形式,或者有没有第三方的控件可以这样做

    阅读更多
  • 这个错误不是编译器的错误,而是IntelliSense的错误。
    这种情况,可以不用太担心。

    如果你使用MSVC编译应用程序,那么最好安装Qt Visual Studio Addon,使用这个插件同步开发Qt应用程序。
    不过一个小小的建议,就是Qt Creator写Qt程序非常直观,不需要在Visual Studio中那么麻烦,而且Qt Creator是强制安装的,基本上你安装了Qt 5.12,就可以在安装的目录中找到它。QAxContainer是Qt的模块activeQt中的,需要在pro文件中写QT += axcontainer,才会找到这个类。

    阅读更多
  • C

    VS2017 Qt5.12
    新建一个空的QWidget对话框,编译执行
    可以成功生成并执行,但是错误列表里显示

    傲游截图20190217212931.png

    exe文件能够成功生成。

    另外的问题:我在vs2017编译环境中使用qt,需要用到 QAxContainer,我看帮助文档里说要在.pro中加入CONFIG+=qaxcontainer,但是vs2017创建的程序中没有.pro这个文件,那这句话应该加在哪里呢?

    还有我想建一个有浏览器控件的对话框程序,如果想在5.12版本中加入QtWebKit应该如何使用

    阅读更多

关注我们

微博
QQ群











召唤伊斯特瓦尔