第二课:Qt 的 qDebug() 等信息自动生成 log 日志

功能描述:将 qDebug()、qWarning()、qCritical()、qFatal() 输出信息保存为 log 日志

第一步:在 .pro 文件中添加  DEFINES += QT_MESSAGELOGCONTEXT 

DEFINES += QT_MESSAGELOGCONTEXT

第二步:编写日志生成函数 myMessageOutput( )

void myMessageOutput(QtMsgType type, const QMessageLogContext &context, const QString &msg)
{
    //加锁,防止多用户同时读写
    static QMutex mutex;
    mutex.lock();

    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;
    default:
        break;
    }

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

    // 输出信息至文件中(读写、追加形式)
    QFile file("log.txt");
    file.open(QIODevice::ReadWrite | QIODevice::Append);
    QTextStream stream(&file);
    stream << strMessage << "\n";
    file.flush();
    file.close();

    // 解锁
    mutex.unlock();
}

第三步:安装消息处理程序 qInstallMessageHandler()

qInstallMessageHandler(myMessageOutput);

程序运行后生成 log.txt 文件,其内容如下所示:

第二课:Qt 的 qDebug() 等信息自动生成 log 日志_第1张图片

你可能感兴趣的:(Qt)