qt log 输出为文件,每分钟换一个log文件

1.qt log 输出为文件,每分钟换一个log文件

在Qt中,如果你想要每分钟将日志输出到一个新的文件中,你需要实现一个自定义的日志处理机制。以下是一个基本的实现方法:

  1. 创建一个日志管理类:这个类将负责处理日志的写入,并根据时间判断是否需要创建新的日志文件。

  2. 安装消息处理器 :使用qInstallMessageHandler来安装一个自定义的消息处理器,该处理器会将日志消息传递给日志管理类。

  3. 定时检查并滚动日志文件 :在日志管理类中,你可以使用一个定时器(如QTimer)来每分钟检查是否需要滚动日志文件。

以下是一个简化的示例代码,展示了如何实现这一功能:

#include <QCoreApplication>  
#include <QFile>  
#include <QTextStream>  
#include <QDateTime>  
#include <QTimer>  
#include <QMessageLogger>  
  
class LogManager : public QObject {  
    Q_OBJECT  
public:  
    LogManager(QObject *parent = nullptr) : QObject(parent) {  
        // 初始化日志文件  
        rollLogFile();  
  
        // 设置定时器,每分钟检查一次是否需要滚动日志文件  
        QTimer *timer = new QTimer(this);  
        connect(timer, &QTimer::timeout, this, &LogManager::checkLogFile);  
        timer->start(60000); // 每分钟触发一次  
    }  
  
    void writeLog(const QString &message) {  
        if (!logFile.isOpen()) {  
            logFile.open(QIODevice::Append | QIODevice::Text);  
        }  
        QTextStream out(&logFile);  
        out << QDateTime::currentDateTime().toString("yyyy-MM-dd HH:mm:ss.zzz ") << message << endl;  
        logFile.flush(); // 确保日志被写入文件  
    }  
  
private slots:  
    void checkLogFile() {  
        rollLogFile(); // 每分钟检查并可能滚动日志文件  
    }  
  
private:  
    void rollLogFile() {  
        if (logFile.isOpen()) {  
            logFile.close();  
        }  
  
        // 根据当前时间创建新的日志文件名称  
        QString logFileName = QDir::currentPath() + "/log_" + QDateTime::currentDateTime().toString("yyyyMMdd_HHmm") + ".txt";  
        logFile.setFileName(logFileName);  
    }  
  
    QFile logFile;  
};  
  
void customMessageHandler(QtMsgType type, const QMessageLogContext &context, const QString &msg) {  
    static LogManager *logManager = new LogManager();  
    logManager->writeLog(msg); // 将日志消息写入文件  
}  
  
int main(int argc, char *argv[]) {  
    QCoreApplication a(argc, argv);  
  
    qInstallMessageHandler(customMessageHandler); // 安装自定义消息处理器  
  
    // 测试日志输出  
    qDebug() << "This is a debug message";  
  
    return a.exec();  
}  
  
#include "main.moc" // 对于使用Qt的信号和槽机制的类,需要包含moc文件

在这个示例中,LogManager 类负责管理日志文件,包括写入日志和定时滚动日志文件。customMessageHandler 函数作为自定义消息处理器,它会将日志消息传递给 LogManager 实例进行写入。QTimer 用于每分钟触发一次日志文件的滚动检查。

请注意,这个示例是简化的,并且没有处理多线程访问或日志文件清理等高级功能。在生产环境中,你可能需要考虑这些额外因素。

2.qt log 输出为文件,每分钟换一个log文件,将头文件和源文件分开

在Qt中,要实现日志输出到文件,并且每分钟自动更换一个新的日志文件,同时保持代码的模块化,你可以将相关的功能分解到头文件和源文件中。下面是一个简单的示例来展示如何实现这一功能。

头文件(LogManager.h)

#ifndef LOGMANAGER_H  
#define LOGMANAGER_H  
  
#include <QObject>  
#include <QFile>  
#include <QTextStream>  
#include <QDateTime>  
#include <QTimer>  
  
class LogManager : public QObject {  
    Q_OBJECT  
  
public:  
    explicit LogManager(QObject *parent = nullptr);  
    ~LogManager();  
  
    void writeLog(const QString &message);  
  
private slots:  
    void rollLogFile();  
  
private:  
    QFile logFile;  
    QTimer *timer;  
};  
  
#endif // LOGMANAGER_H

源文件(LogManager.cpp)

#include "LogManager.h"  
#include <QDir>  
  
LogManager::LogManager(QObject *parent) : QObject(parent) {  
    // 初始化日志文件  
    rollLogFile();  
  
    // 设置定时器,每分钟滚动日志文件  
    timer = new QTimer(this);  
    connect(timer, &QTimer::timeout, this, &LogManager::rollLogFile);  
    timer->start(60000); // 每分钟触发一次  
}  
  
LogManager::~LogManager() {  
    if (logFile.isOpen()) {  
        logFile.close();  
    }  
    delete timer;  
}  
  
void LogManager::writeLog(const QString &message) {  
    if (!logFile.isOpen()) {  
        logFile.open(QIODevice::Append | QIODevice::Text);  
    }  
    QTextStream out(&logFile);  
    out << QDateTime::currentDateTime().toString("yyyy-MM-dd HH:mm:ss.zzz ") << message << endl;  
    logFile.flush(); // 确保日志被写入文件  
}  
  
void LogManager::rollLogFile() {  
    if (logFile.isOpen()) {  
        logFile.close();  
    }  
  
    // 根据当前时间创建新的日志文件名称  
    QString logFileName = QDir::currentPath() + "/log_" + QDateTime::currentDateTime().toString("yyyyMMdd_HHmm") + ".txt";  
    logFile.setFileName(logFileName);  
}

自定义消息处理器(messageHandler.cpp)

#include "LogManager.h"  
#include <QCoreApplication>  
  
static LogManager *logManagerInstance = nullptr;  
  
void customMessageHandler(QtMsgType type, const QMessageLogContext &context, const QString &msg) {  
    if (!logManagerInstance) {  
        logManagerInstance = new LogManager(qApp);  
    }  
    logManagerInstance->writeLog(msg);  
}

主函数(main.cpp)

#include <QCoreApplication>  
#include "LogManager.h"  
#include "messageHandler.cpp" // 包含自定义消息处理器  
  
int main(int argc, char *argv[]) {  
    QCoreApplication a(argc, argv);  
  
    qInstallMessageHandler(customMessageHandler); // 安装自定义消息处理器  
  
    // 测试日志输出  
    qDebug() << "This is a debug message";  
  
    return a.exec();  
}

在这个例子中,LogManager 类被定义在一个单独的头文件和源文件中,负责日志文件的创建、写入和滚动。自定义消息处理器customMessageHandler被定义在messageHandler.cpp中,它使用LogManager的实例来写入日志。主函数main.cpp中安装了这个消息处理器,并输出了一个测试日志消息。

请注意,这个实现是线程不安全的。如果你在多线程环境中使用它,你需要添加适当的锁来确保对logFile的访问是线程安全的。此外,这个简单的实现没有处理日志文件的清理或归档,这在实际应用中可能是必要的。

相关推荐
代码驿站5201 小时前
Scala语言的面向对象编程
开发语言·后端·golang
不是只有你能在乱世中成为大家的救世主2 小时前
学习第六十四行
linux·c语言·开发语言·经验分享·学习
JoneMaster3 小时前
[读书日志]从零开始学习Chisel 第十一篇:Scala的类型参数化(敏捷硬件开发语言Chisel与数字系统设计)
开发语言·学习·scala
吴秋霖3 小时前
某漫画网站JS逆向反混淆流程分析
开发语言·javascript·ecmascript
Growthofnotes3 小时前
C++—14、C++ 中的指针最基础的原理
开发语言·c++
MilesMatheson3 小时前
ubuntu 编译android源码报错:loadlocale.c:129: _nl_intern_locale_data:
c语言·开发语言·算法
sysu634 小时前
73.矩阵置零 python
开发语言·数据结构·python·线性代数·leetcode·面试·矩阵
程序员奇奥4 小时前
统计有序矩阵中的负数
线性代数·算法·矩阵
Stealmoon_94 小时前
快速、简单的2D-6D位姿估计:Gen6D算法复现 (pytorch 1.12.1 + cu113)
人工智能·pytorch·算法
写代码的熊萌新4 小时前
JAVA2-类与对象编程(1)
java·开发语言