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的访问是线程安全的。此外,这个简单的实现没有处理日志文件的清理或归档,这在实际应用中可能是必要的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值