Qt实现输出日志到指定文件的操作方法

 更新时间:2024年07月30日 10:31:03   作者:Uranus^  
这篇文章主要介绍了Qt实现输出日志到指定文件的操作方法,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧

开发平台 :

Qt Creator

语言:

C++

需求:

  • 获取日志信息,写入指定文件
  • 日志7天后过期
  • 保护写入日志进程

前置操作:

1.在CMakeLists.txt中添加如下代码

# 添加预处理,防止在release模式下,输出的日志信息不显示文件名,行号等信息
add_definitions(-DQT_MESSAGELOGCONTEXT)

2.创建LogManage.h 和 LogManage.cpp

具体代码:

LogManage.h

#pragma once
#include <QApplication>
#include <QtDebug>
#include <QFile>
#include <QTextStream>
#include <qdatetime.h>
//初始化
void InitalizeLog();
//获取日志存储目录路径
QString getLogFilePath();
//日志处理
void LogMessageHandler(QtMsgType type,const QMessageLogContext &context, const QString &messages);

LogManage.cpp

#include "src/LogManage.h"
#include <qdir.h>
#include <QDateTime>
#include <QFileInfoList>
#include <qfileinfo.h>
#include <QMutex>
void InitalizeLog()
{
    //1. 预设日志目录并检查是否创建
    QString path = getLogFilePath();
    QDir dir(path);
    if(!dir.exists()){
        dir.mkdir(path);
    }
    //2. 日志7天后过期逻辑
    QDateTime last_time = QDateTime::currentDateTime().addDays(-7);
    QFileInfoList infoList = dir.entryInfoList();
    for(QFileInfo info : infoList){
        if(info.fileName() == "." || info.fileName() == ".."){
            continue;
        }
        if(last_time.secsTo(info.birthTime()) < 0){//secsTo: 差多少秒到
            info.dir().remove(info.fileName());
        }
    }
}
void LogMessageHandler(QtMsgType type, const QMessageLogContext &context, const QString &message)
{
    //1. 加锁,保护进程
    static QMutex mutex;//互斥锁 QMutex
    mutex.lock();
    //2. 日志信息生成及处理
    /*** 1.日志消息类型 ***/
    QString m_type("");
    switch (type) {
    case QtDebugMsg:
        m_type = QString("Debug");
        break;
    case QtInfoMsg:
        m_type = QString("Info");
        break;
    case QtWarningMsg:
        m_type = QString("Warning");
        break;
    case QtCriticalMsg:
        m_type = QString("Critical");
        break;
    case QtFatalMsg:
        m_type = QString("Fatal");
        break;
    }
    /*** 2.日志消息 ***/
    QByteArray m_message = message.toUtf8();
    /*** 3.日志生成日期 ***/
    QString m_date = QDateTime::currentDateTime().toString("yyyy-mm-dd hh:mm::ss");
    /*** 4.日志所在文件&行 ***/
    QString m_file = context.file;
    int m_line = context.line;
    QString m_log = QString("[%1]-<文件:%2    所在行:%3    日期:%4> ----------------- %5")
                        .arg(m_type).arg(m_file).arg(m_line).arg(m_date).arg(m_message);
    //3. 日志写入预设文件
    QString m_filePath = getLogFilePath();
    QString m_fileName = QDate::currentDate().toString("yyyy-MM-dd");
    m_fileName += ".txt";
    m_fileName = m_filePath + "/" + m_fileName;
    m_fileName = QDir::toNativeSeparators(m_fileName);
    QFile file(m_fileName);
    file.open(QIODevice::ReadWrite | QIODevice::Append);
    QTextStream stream(&file);
    stream<< m_log << "\r\n";
    file.flush(); //直接将缓冲中的内容写入文件
    file.close();
    //4. 解锁
    mutex.unlock();
}
QString getLogFilePath()
{
    QString str = qApp->applicationDirPath();
    str = str.left(str.lastIndexOf("/"));
    str += "/myLog";
    str = QDir::toNativeSeparators(str);//toNativeSeparators: 转到本地分隔符
    return str;
}

main.cpp

int main(int argc, char *argv[])
{
//release模式下启动日志文件输出
#ifdef QT_NO_DEBUG
    InitalizeLog();
    //自定义日志输出
    qInstallMessageHandler(LogMessageHandler);
#endif
//other..
//other..
//other..
//other..
}

到此这篇关于Qt实现输出日志到指定文件的文章就介绍到这了,更多相关Qt输出日志到指定文件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C++高精度算法的使用场景详解

    C++高精度算法的使用场景详解

    在我们进行计算的过程中,经常会遇到几十位,甚至几百位的数字的计算问题,也有可能会遇到小数点后几十位,几百位的情况,而我们面对这样的情况下,long long  和 double 的数据范围显然是不够使用的了。因此这时,我们就需要引入一个新的算法,叫做高精度算法
    2022-09-09
  • Matlab实现绘制雷达图(蜘蛛图)

    Matlab实现绘制雷达图(蜘蛛图)

    这篇文章主要为大家详细介绍了如何利用Matlab实现雷达图(蜘蛛图)的绘制,文中的示例代码讲解详细,对我们学习Matlab有一定帮助,需要的可以参考一下
    2022-09-09
  • C语言中memcpy 函数的用法详解

    C语言中memcpy 函数的用法详解

    这篇文章主要介绍了C语言中memcpy 函数的用法详解的相关资料,需要的朋友可以参考下
    2017-07-07
  • C语言实现猜数字大小的游戏

    C语言实现猜数字大小的游戏

    这篇文章主要为大家详细介绍了C语言实现猜数字大小的游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-01-01
  • C语言基于EasyX绘制时钟

    C语言基于EasyX绘制时钟

    这篇文章主要为大家详细介绍了C语言基于EasyX绘制时钟,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-06-06
  • 浅谈C++反向迭代器的设计

    浅谈C++反向迭代器的设计

    本文主要介绍了浅谈C++反向迭代器的设计,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-04-04
  • c语言实现向上取整计算方法

    c语言实现向上取整计算方法

    这篇文章主要介绍了c语言实现向上取整计算方法,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • C++11智能指针中的 unique_ptr实例详解

    C++11智能指针中的 unique_ptr实例详解

    unique是独特的、唯一的意思,故名思议,unique_ptr可以“独占”地拥有它所指向的对象,它提供一种严格意义上的所有权。这篇文章主要介绍了C++11智能指针中的 unique_ptr实例详解,需要的朋友可以参考下
    2020-06-06
  • C++ 中使用lambda代替 unique_ptr 的Deleter的方法

    C++ 中使用lambda代替 unique_ptr 的Deleter的方法

    这篇文章主要介绍了C++ 中使用lambda代替 unique_ptr 的Deleter的方法,需要的朋友可以参考下
    2017-04-04
  • C++基于socket多线程实现网络聊天室

    C++基于socket多线程实现网络聊天室

    这篇文章主要为大家详细介绍了C++基于socket多线程实现网络聊天室,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07

最新评论