Qt日志输出重定向自定义格式

原文链接

欢迎大家对于本站的访问 - AsterCasc

前言

Qt日志输出重定向示例,这里增加自动将不同日期的日志分开存储的逻辑,方便日志管理和查阅

实现

关键函数就一个

typedef void (*QtMessageHandler)(QtMsgType, const QMessageLogContext &, const QString &);
Q_CORE_EXPORT QtMessageHandler qInstallMessageHandler(QtMessageHandler);

我们只需要在代码初始位置,将自己的处理方法由qInstallMessageHandler注入,即可实现日志输出的多态,这里给出简单示例

头文件log_record.h

#ifndef LOGRECORD_H
#define LOGRECORD_H

#include <QDateTime>
#include <QDebug>
#include <QFile>
#include <QIODevice>
#include <QObject>

class LogRecord : public QObject
{
    Q_OBJECT
public:
    explicit LogRecord(QObject* parent = nullptr);
    ~LogRecord();

public:
    void installLogHandle();

public:
    static void    rebuildLogFile();
    static void    closeLogFile();
    static QFile*  getCurFilePtr();
    static QString getCurDate();

private:
    static QString s_curDate;
    static QFile*  s_logFilePtr;
};

#endif  // LOGRECORD_H

源文件log_record.cpp

#include "log_record.h"

QFile*  LogRecord::s_logFilePtr = nullptr;
QString LogRecord::s_curDate    = "";

void handle(QtMsgType, const QMessageLogContext& context, const QString& msg)
{
    if (LogRecord::getCurDate() != QDateTime::currentDateTime().toString("yyyyMMdd"))
    {
        LogRecord::closeLogFile();
        LogRecord::rebuildLogFile();
    }

    auto logFile = LogRecord::getCurFilePtr();
    if (logFile)
    {
        QString date = QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss");
        QString output =
            QString("[%1] [%2:%3] %4\n").arg(date).arg(context.file).arg(context.line).arg(msg);
        QTextStream stream(logFile);
        stream << output;
    }
}

LogRecord::LogRecord(QObject* parent) : QObject{ parent }
{
    LogRecord::rebuildLogFile();
}

LogRecord::~LogRecord()
{
    LogRecord::closeLogFile();
}

void LogRecord::installLogHandle()
{
    qInstallMessageHandler(handle);
}

void LogRecord::rebuildLogFile()
{
    QString date = QDateTime::currentDateTime().toString("yyyyMMdd");
#ifdef Q_OS_WIN
    s_logFilePtr = new QFile(QString("log-%1.txt").arg(date));
#else
    s_logFilePtr = new QFile(QString("/data/face/log/log-%1.txt").arg(date));
#endif
    if (s_logFilePtr->open(QIODevice::Append | QIODevice::WriteOnly))
    {
        s_curDate = date;
    }
    else
    {
        qDebug() << "[op:LogRecord] Load log file fail ";
    }
}

void LogRecord::closeLogFile()
{
    s_logFilePtr->close();
    delete s_logFilePtr;
}

QFile* LogRecord::getCurFilePtr()
{
    return s_logFilePtr;
}

QString LogRecord::getCurDate()
{
    return s_curDate;
}

调用在应用初始化位置增加代码

#ifndef Q_OS_WIN
        m_logRecord = new LogRecord();
        m_logRecord->installLogHandle();
#endif

即可

原文链接

欢迎大家对于本站的访问 - AsterCasc

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要发送自定义数据包格式,可以使用 Qt 的网络编程模块中的 QTcpSocket 类。具体实现步骤如下: 1. 在自定义数据包格式中,我们需要定义数据包的头部和数据部分。数据包的头部用于描述数据包的类型、长度等信息,数据部分则是我们要发送的具体数据。在 Qt 中,可以使用结构体或类来定义数据包的格式。 2. 在发送数据前,需要创建一个 QTcpSocket 对象并连接目标主机。连接成功后,可以通过 write() 函数向主机发送数据。 3. Qt 中的 write() 函数默认发送的是 QByteArray 类型的数据,因此我们需要将自定义的数据包格式转换成 QByteArray 类型的数据。可以使用 QByteArray 类的 append() 函数将数据包的头部和数据部分拼接在一起,然后发送给目标主机。 4. 在发送数据时,需要注意网络字节序的问题。一般情况下,我们需要将数据包的头部中的整型数据转换为网络字节序(大端字节序)后再发送。 下面是一个简单的示例代码,演示如何发送一个自定义的数据包格式: ```cpp #include <QTcpSocket> #include <QDataStream> // 自定义数据包格式 struct Packet { quint16 type; // 数据包类型 quint16 length; // 数据包长度 QByteArray data; // 数据部分 }; void sendPacket(Packet packet, QTcpSocket* socket) { // 将数据包转换成 QByteArray 类型 QByteArray packetData; QDataStream stream(&packetData, QIODevice::WriteOnly); stream << packet.type << packet.length << packet.data; // 发送数据包 socket->write(packetData); } int main() { // 创建 QTcpSocket 对象并连接目标主机 QTcpSocket socket; socket.connectToHost("127.0.0.1", 8888); if (!socket.waitForConnected()) { return -1; } // 构造数据包 Packet packet; packet.type = 1; packet.data = "Hello World!"; packet.length = packet.data.size(); // 发送数据包 sendPacket(packet, &socket); return 0; } ``` 以上代码只是一个简单的示例,实际应用中需要根据具体的需求和协议来设计自定义数据包格式

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值