进军Qt 5.x,日志

发布于 2020-10-29  261 次阅读


#include <QDebug>
#include <QFile>
#include <QString>

#include <QtGlobal>
#ifdef Q_OS_MAC
#define LINE_BREAK '\n'
#endif

#ifdef Q_OS_LINUX
#define LINE_BREAK '\n'
#endif

#ifdef Q_OS_WIN32
#define LINE_BREAK '\r\n'
#endif

void myMessageOutput(QtMsgType type, const QMessageLogContext &context, const QString &msg)
{
    static QMutex mutex;
    mutex.lock();

    QByteArray localMsg = msg.toLocal8Bit();
    QString strMsg("");
    switch(type)
    {
    case QtDebugMsg:
        strMsg = QString("Debug");
        break;
    case QtWarningMsg:
        strMsg = QString("Warning");
        break;
    case QtCriticalMsg:
        strMsg = QString("Critical");
        break;
    case QtFatalMsg:
        strMsg = QString("Fatal");
        break;
    case QtInfoMsg:
        strMsg = QString("Info");
    }


    // 设置输出信息格式
    QString strDateTime = QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss");
    QString strMessage = QString("[%1][%2][%3][%4]%5")
            .arg(strDateTime).arg(strMsg).arg(context.file).arg(context.line).arg(localMsg.constData());

    // 输出信息至文件中(读写、追加形式)
    QFile file( QString("./%1.log").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd")) );
    file.open(QIODevice::ReadWrite | QIODevice::Append);
    QTextStream stream(&file);
    stream << strMessage << LINE_BREAK;
    file.flush();
    file.close();

    mutex.unlock();
}

int main(int argc, char *argv[])
{
    qInstallMessageHandler(myMessageOutput);

    qDebug() << "this is a debug message" ;
}