19网站建设,旅游的网站怎么做,网站备案主体更换,wordpress开启vip会员查看系列文章目录
第一章 qt日志文件生成功能 文章目录 系列文章目录前言一、qt日志文件生成功能二、使用步骤1.代码示例2.运行截图 前言
qt有固定的调试日志接口#xff0c;可以通过终端去打印#xff0c;但是仅适用在本地去调试#xff0c;例如想长期放到测试台去检测#…系列文章目录
第一章 qt日志文件生成功能 文章目录 系列文章目录前言一、qt日志文件生成功能二、使用步骤1.代码示例2.运行截图 前言
qt有固定的调试日志接口可以通过终端去打印但是仅适用在本地去调试例如想长期放到测试台去检测 可以采用生成日志文件的方式去监测.
关键字日志文件 一、qt日志文件生成功能
枚举类型详情qDebug调试信息qInfo正常信息qWarning警告信息qCritical严重错误qFatal致命错误
二、使用步骤
qt目录结构
1.代码示例 代码如下示例 custommessagehandler.h
#ifndef CUSTOMMESSAGEHANDLER_H
#define CUSTOMMESSAGEHANDLER_H#include QtCore
class CustomMessageHandler
{
public:CustomMessageHandler();static void customMessageOutput(QtMsgType type, const QMessageLogContext context, const QString msg);
};#endif // CUSTOMMESSAGEHANDLER_Hcustommessagehandler.cpp
#include QFile
#include QTextStream
#include QDateTime#include custommessagehandler.hCustomMessageHandler::CustomMessageHandler()
{}void CustomMessageHandler::customMessageOutput(QtMsgType type, const QMessageLogContext context, const QString msg)
{// 打开文件确保文件存在并具有写入权限//QFile file(D:/work/lmp/qtproject/untitled/logfile.txt);QFile file(logfile.txt);if (!file.open(QIODevice::Append | QIODevice::Text)) {return;}// 根据消息类型添加前缀QString text;switch (type) {case QtDebugMsg:text QString(Debug: %1).arg(msg);break;case QtInfoMsg:text QString(Info: %1).arg(msg);break;case QtWarningMsg:text QString(Warning: %1).arg(msg);break;case QtCriticalMsg:text QString(Critical: %1).arg(msg);break;case QtFatalMsg:text QString(Fatal: %1).arg(msg);// 注意QtFatalMsg 会导致应用程序终止因此这里可能无法写入完整的消息break;default:text msg;break;}// 写入文件并关闭QTextStream out(file);out QDateTime::currentDateTime().toString(yyyy-MM-dd HH:mm:ss.zzz ) text endl;file.close();
}
main.cpp
#include mainwindow.h
#include QApplication
#include custommessagehandler.h
#include QDebugint main(int argc, char *argv[])
{QApplication a(argc, argv);// add code start// 安装自定义消息处理器qInstallMessageHandler(CustomMessageHandler::customMessageOutput);qInfo() Application started;//输出一般性信息用于记录应用程序运行过程中的常规信息帮助开发者了解程序执行流程。qDebug() Variable value ;//主要用于调试目的输出详细的调试信息。qWarning() Invalid input detected, using default value;//输出警告信息表示程序运行过程中出现了潜在的问题但并没有阻止程序继续执行qCritical() Critical failure in network connection;//输出严重错误信息强调程序发生了严重的、可能会导致程序异常或严重影响程序功能的情况但程序仍然能够运行并可能有机会尝试恢复。// qFatal(Unrecoverable system error occurred);//输出致命错误信息表示发生了非常严重、无法恢复的错误通常这类错误会导致程序立即终止// ... 你的应用程序代码 ...//add code endMainWindow w;w.show();return a.exec();
}
2.运行截图