欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Qt5實現(xiàn)qDebug日志信息寫入日志文件過程

 更新時間:2022年05月09日 15:16:38   作者:xiaoyaoyou.xyz  
這篇文章主要為大家介紹了Qt5實現(xiàn)qDebug日志信息寫入日志文件的過程示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

1、思路

其實Qt提供了將日志寫入文件的方式,是以接口的形式提供的,我們只需要按照我們的需求完成回調(diào)函數(shù)和我們自己的接口即可。

為方便調(diào)用,我們一般直接寫到log.h中即可。

  • 1、創(chuàng)建log.h
  • 2、根據(jù)我們自己的需求完成回調(diào)函數(shù)
  • 3、根據(jù)需求封裝外部調(diào)用函數(shù)并注冊回調(diào)函數(shù)

2、代碼

我這里按照我的需求,當(dāng)接口傳遞日志文件名和等級時使用傳遞的文件存儲日志,否則以精確到當(dāng)前時間為文件名創(chuàng)建日志文件。

提供給外部的調(diào)用函數(shù)包含日志文件名和日志等級兩個接口,可以不傳遞,直接使用默認(rèn)值。

Log.h

#ifndef LOG_H#define LOG_H#include <QFile>#include <QTextStream>#include <QDateTime>#include <QMutex>//選擇屏幕打印還是輸出到文件可以根據(jù)這個宏控制或者控制函數(shù)調(diào)用位置都可以//#define _DEBUG//默認(rèn)調(diào)試級別為warning,即小于warning級別的都不會寫入日志文件//只有release版本的時候,才會輸出到日志,debug版本正常輸出到終端。namespace QT_LOG{<!--{C}%3C!%2D%2D%20%2D%2D%3E--> //默認(rèn)文件名為當(dāng)前時間命名的log文件 static int m_LogLevel = 1; static QString m_LogFile = QString("%1.log").arg(QDateTime::currentDateTime().toString("yyyyMMddhhmmss")); QMutex m_LogMutex; void customMessageHandler(QtMsgType type , const QMessageLogContext &context , const QString &msg) {<!--{C}%3C!%2D%2D%20%2D%2D%3E--> //設(shè)置輸出日志級別,小于該級別,將不會寫入日志文件,默認(rèn)是warning級別,即debug信息不會寫入日志文件 if (type < m_LogLevel) {<!--{C}%3C!%2D%2D%20%2D%2D%3E--> return; } QString log_info; switch (type) {<!--{C}%3C!%2D%2D%20%2D%2D%3E--> case QtDebugMsg: log_info = QString("%1[Debug]:").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss")); break; case QtWarningMsg: log_info = QString("%1[Warning]:").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss")); break; case QtCriticalMsg: log_info = QString("%1[Critical]:").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss")); break; case QtFatalMsg: log_info = QString("%1[Fatal]:").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss")); abort(); case QtInfoMsg: log_info = QString("%1[Info]:").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss")); break; } log_info += QString(context.file) + QString(context.line) + QString("%1").arg(msg); //為了線程安全 m_LogMutex.lock(); QFile outFile(m_LogFile); outFile.open(QIODevice::WriteOnly | QIODevice::Append | QIODevice::Text); QTextStream ts(&outFile); ts << log_info << endl; outFile.close(); m_LogMutex.unlock(); } //默認(rèn)調(diào)試級別為warning及以上才會寫入日志文件,默認(rèn)log文件名為程序啟動時間命名的log文件 void logInit(QString logFile = "", int logLevel = 1) {<!--{C}%3C!%2D%2D%20%2D%2D%3E--> #ifndef _DEBUG //實現(xiàn)debug版本的時候,輸出到終端;release版本的時候輸出到日志文件 if ((logLevel < 0) || (logLevel > 3)) {<!--{C}%3C!%2D%2D%20%2D%2D%3E--> m_LogLevel = 1; } else {<!--{C}%3C!%2D%2D%20%2D%2D%3E--> m_LogLevel = logLevel; } if (!logFile.isEmpty()) {<!--{C}%3C!%2D%2D%20%2D%2D%3E--> m_LogFile = logFile; } qInstallMessageHandler(customMessageHandler); #endif }}#endif // LOG_H#ifndef LOG_H
#define LOG_H
#include <QFile>
#include <QTextStream>
#include <QDateTime>
#include <QMutex>
//選擇屏幕打印還是輸出到文件可以根據(jù)這個宏控制或者控制函數(shù)調(diào)用位置都可以
//#define _DEBUG
//默認(rèn)調(diào)試級別為warning,即小于warning級別的都不會寫入日志文件
//只有release版本的時候,才會輸出到日志,debug版本正常輸出到終端。
namespace QT_LOG
{
    //默認(rèn)文件名為當(dāng)前時間命名的log文件
    static int m_LogLevel = 1;
    static QString m_LogFile = QString("%1.log").arg(QDateTime::currentDateTime().toString("yyyyMMddhhmmss"));
    QMutex m_LogMutex;
    void customMessageHandler(QtMsgType type , const QMessageLogContext &context , const QString &msg)
    {
        //設(shè)置輸出日志級別,小于該級別,將不會寫入日志文件,默認(rèn)是warning級別,即debug信息不會寫入日志文件
        if (type < m_LogLevel)
        {
            return;
        }
        QString log_info;
        switch (type)
        {
        case QtDebugMsg:
            log_info = QString("%1[Debug]:").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss"));
            break;
        case QtWarningMsg:
            log_info = QString("%1[Warning]:").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss"));
            break;
        case QtCriticalMsg:
            log_info = QString("%1[Critical]:").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss"));
            break;
        case QtFatalMsg:
            log_info = QString("%1[Fatal]:").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss"));
            abort();
        case QtInfoMsg:
            log_info = QString("%1[Info]:").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss"));
            break;
        }
        log_info += QString(context.file) + QString(context.line) + QString("%1").arg(msg);
        //為了線程安全
        m_LogMutex.lock();
        QFile outFile(m_LogFile);
        outFile.open(QIODevice::WriteOnly | QIODevice::Append | QIODevice::Text);
        QTextStream ts(&outFile);
        ts << log_info << endl;
        outFile.close();
        m_LogMutex.unlock();
    }
    //默認(rèn)調(diào)試級別為warning及以上才會寫入日志文件,默認(rèn)log文件名為程序啟動時間命名的log文件
    void logInit(QString logFile = "", int logLevel = 1)
    {
        #ifndef _DEBUG  //實現(xiàn)debug版本的時候,輸出到終端;release版本的時候輸出到日志文件
            if ((logLevel < 0) || (logLevel > 3))
            {
                m_LogLevel = 1;
            }
            else
            {
                m_LogLevel = logLevel;
            }
            if (!logFile.isEmpty())
            {
                m_LogFile = logFile;
            }
            qInstallMessageHandler(customMessageHandler);
        #endif
    }
}
#endif // LOG_H

調(diào)用,包含頭文件后直接調(diào)用參數(shù)即可:

QT_LOG::logInit();//或者QT_LOG::logInit("log.txt", 2);QT_LOG::logInit();
//或者
QT_LOG::logInit("log.txt", 2);

3、問題

可能不通Qt版本提供的回調(diào)函數(shù)有差異,我們通過qInstallMessageHandler進(jìn)行源碼查看,看下回調(diào)函數(shù)的樣式,實現(xiàn)對應(yīng)的回調(diào)函數(shù)進(jìn)行測試即可:

在這里插入圖片描述

4、結(jié)果與擴(kuò)展思路

這個是我使用我上面封裝的函數(shù)后生成的日志文件,每一次啟動創(chuàng)建一個,暫時沒有考慮定時分割創(chuàng)建新文件等問題,如果有需求可以調(diào)整回調(diào)函數(shù)進(jìn)行調(diào)試:

在這里插入圖片描述

針對上面的日志我們還可以加一些定時任務(wù)或者直接通過內(nèi)存數(shù)據(jù)庫通過線程安全的方式直接存儲到數(shù)據(jù)庫中,這樣便于分布式存儲和分析操作日志。

以上就是Qt5實現(xiàn)qDebug日志信息寫入日志文件的詳細(xì)內(nèi)容,更多關(guān)于Qt5 qDebug日志信息寫入文件的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • C++關(guān)鍵字const使用方法詳解

    C++關(guān)鍵字const使用方法詳解

    C語言中的const與C++有很大的不同,在C語言中用const修飾的變量仍是一個變量,表示這個變量是只讀的,不可顯示地更改,C++中的const關(guān)鍵字的用法非常靈活,而使用const將大大改善程序的健壯性,const關(guān)鍵字是一種修飾符
    2022-12-12
  • 詳解c/c++鏈?zhǔn)蕉褩C枋鲞M(jìn)制轉(zhuǎn)換問題示例

    詳解c/c++鏈?zhǔn)蕉褩C枋鲞M(jìn)制轉(zhuǎn)換問題示例

    這篇文章主要為大家介紹了c/c++鏈?zhǔn)蕉褩C枋鲞M(jìn)制轉(zhuǎn)換問題示例解析有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2021-11-11
  • 漫畫講解C語言中最近公共祖先的三種類型

    漫畫講解C語言中最近公共祖先的三種類型

    這篇文章主要總結(jié)了使用C語言查找最近公共祖先的三種方法類型,用漫畫的方式講解原理定義,看上去更生動形象,幫助你更好的理解透徹,快來跟著本文往下看吧
    2021-11-11
  • QT Creator+OpenCV實現(xiàn)圖像灰度化的示例代碼

    QT Creator+OpenCV實現(xiàn)圖像灰度化的示例代碼

    這篇文章主要為大家詳細(xì)介紹了QT如何利用Creator和OpenCV實現(xiàn)圖像灰度化效果,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以嘗試一下
    2022-12-12
  • C語言詳解鏈?zhǔn)疥犃信c循環(huán)隊列的實現(xiàn)

    C語言詳解鏈?zhǔn)疥犃信c循環(huán)隊列的實現(xiàn)

    隊列(Queue)與棧一樣,是一種線性存儲結(jié)構(gòu),它具有如下特點:隊列中的數(shù)據(jù)元素遵循“先進(jìn)先出”(First In First Out)的原則,簡稱FIFO結(jié)構(gòu)。在隊尾添加元素,在隊頭刪除元素,本篇來講解鏈?zhǔn)疥犃信c循環(huán)隊列的實現(xiàn)
    2022-04-04
  • C++寫時拷貝實現(xiàn)原理及實例解析

    C++寫時拷貝實現(xiàn)原理及實例解析

    這篇文章主要介紹了C++寫時拷貝實現(xiàn)原理及實例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-06-06
  • C++虛析構(gòu)函數(shù)的使用分析

    C++虛析構(gòu)函數(shù)的使用分析

    本篇文章是對C++虛析構(gòu)函數(shù)的使用進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • vc中float與DWORD的互想轉(zhuǎn)換實現(xiàn)代碼

    vc中float與DWORD的互想轉(zhuǎn)換實現(xiàn)代碼

    這篇文章主要介紹了vc中float與DWORD的互想轉(zhuǎn)換實現(xiàn)代碼,需要的朋友可以參考下
    2017-06-06
  • APUE筆記之:進(jìn)程環(huán)境詳解

    APUE筆記之:進(jìn)程環(huán)境詳解

    本篇文章是對APUE 進(jìn)程環(huán)境詳解進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • C語言常見的指針筆試題解析

    C語言常見的指針筆試題解析

    在我們學(xué)習(xí)指針之后,應(yīng)該在實際應(yīng)用中去理解和掌握它,畢竟實踐才是檢驗真理的唯一標(biāo)準(zhǔn),我們以后在找工作的過程中免不了會遇到與指針相關(guān)的試題,本篇文章可以幫助我們提前了解一些常見的指針考點,需要的可以了解一下
    2022-10-10

最新評論