Qt实现输出日志到指定文件

开发平台 :

Qt Creator

语言:

C++

需求:

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

前置操作:

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..
}
  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Qt是一个跨平台的C++应用程序开发框架,它提供了丰富的功能和工具来开发大型项目。Qt的项目文件结构通常包括以下几个主要部分: 1. 源代码文件:这是项目的核心部分,包含了实现应用程序功能的C++源代码文件。这些文件通常以.cpp为扩展名。 2. 头文件:头文件包含了类、函数和变量的声明,用于在源代码中引用和使用。这些文件通常以.h为扩展名。 3. 资源文件:资源文件包含了应用程序使用的图像、字体、样式表等非代码资源。这些文件通常以.qrc为扩展名,使用Qt资源系统进行管理。 4. UI文件:UI文件是使用Qt的可视化设计工具Qt Designer创建的界面文件,它定义了应用程序的用户界面布局和组件。这些文件通常以.ui为扩展名。 5. 配置文件:配置文件包含了应用程序的配置信息,如数据库连接、日志级别等。这些文件可以使用各种格式,如XML、INI等。 6. 编译配置文件:编译配置文件用于指定项目的编译选项和依赖关系。在Qt中,常用的编译配置文件是.pro文件,它使用Qt的构建系统qmake进行管理。 7. 构建输出目录:构建输出目录是编译和构建过程生成的中间文件和最终可执行文件的存放位置。通常在项目根目录下创建一个build目录用于存放构建输出。 8. 其他辅助文件:除了上述主要部分外,大型Qt项目可能还包含其他辅助文件,如文档、测试脚本、第三方库等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Uranus^

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值