Qt 日志之Qdebug 二次封装类

2024-05-10 06:38
文章标签 日志 封装 qt 二次 qdebug

本文主要是介绍Qt 日志之Qdebug 二次封装类,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

简单的日志库可以用Qdebug做一个注册InstallMessageHandle,还有一种是使用开源的日志库,如Boost 库,Log4Qt 等。开源这些日志功能比较强大,Qdebug的话做些本地运行日志跟踪状态,还是足够的。

根据日期生成文件夹
文件夹存放日志,按时间命名,大于1024 * 1024 * 4 ,(4M)自动新建文件。大小可以根据具体项目更改.
文件自动新增
时间,文件名+行号+level +信息 :
[18:03:58.210][..\testQdebug\main.cpp-11][Info]: test qDebug
[18:03:58.253][..\testQdebug\main.cpp-12][Info]: test qInfo 
[18:06:16.301][..\testQdebug\main.cpp-11][Info]: test qDebug
[18:06:16.301][..\testQdebug\main.cpp-12][Info]: test qInfo 
[18:06:16.302][..\testQdebug\main.cpp-13][Error]: test qCritical 

只需包含如下头文件:
使用时:
CLog::InstallLog(); 初始化
qDebug()<<QStringLiteral"中文消息";
qError()<<…;

#ifndef CLOG_H
#define CLOG_H
/*
文件夹存放日志,按时间命名,大于1024 * 1024 * 4 ,(4M)自动新建文件;大小可以根据具体项目更改.
日志信息格式:  [时间][文件名-行号][level]: 信息
使用示例如下:
#include "mainwindow.h"
#include <QApplication>
#include "clog.h"
int main(int argc, char *argv[])
{QApplication a(argc, argv);//初始化CLog::InstallLog();MainWindow w;w.show();//使用如下qDebug() << "test qDebug";qInfo() << "test qInfo ";qCritical() <<"test qCritical ";return a.exec();
}
*/
#pragma once
//by karlchan cgs
#include <QDateTime>
#include <QFile>
#include <QTextStream>
#include <QApplication>
#include <QDebug>
#include <QDir>
#include <QMutex>
#include <QMutexLocker>static int gIndex = 0;
class CLog
{
public:CLog();~CLog();public:static void InstallLog(){makesureDir();makesureIndex();qInstallMessageHandler(CLog::outputMessage);};
protected:private:static void outputMessage(QtMsgType type, const QMessageLogContext &context, const QString &msg){static QMutex mutex;QMutexLocker locker(&mutex);QString	strDir = QApplication::applicationDirPath() + "/../Log/" + QDateTime::currentDateTime().toString("yyyyMMdd");QString text;switch (type){case QtWarningMsg:text = QString("[Warning]:");break;case QtInfoMsg:case QtDebugMsg:text = QString("[Info]:");break;case QtFatalMsg:case QtCriticalMsg:text = QString("[Error]:");}QString context_info = QString("[%1-%2]").arg(QString(context.file)).arg(context.line);QString current_date_time = QDateTime::currentDateTime().toString("[hh:mm:ss.z]");//yyyy-MM-ddQString current_date = QDateTime::currentDateTime().toString("yyyyMMdd");//zcurrent_date += QString("_%1").arg(gIndex, 3, 10, QChar('0'));QString message = QString("%0%1%2 %3").arg(current_date_time).arg(context_info).arg(text).arg(msg);QString strPath = strDir + "/" + current_date + ".log";QFileInfo fi(strPath);if (fi.size() >= (1024 * 1024 * 10)){gIndex++;current_date = QDateTime::currentDateTime().toString("yyyyMMdd");//zcurrent_date += QString("_%1").arg(gIndex, 3, 10, QChar('0'));}strPath = strDir + "/" + current_date + ".log";QFile file(strPath);if (file.open(QIODevice::WriteOnly | QIODevice::Append)){QTextStream text_stream(&file);text_stream << message << "\r\n";file.flush();file.close();}}static void makesureDir(){QString strDir;strDir = QApplication::applicationDirPath() + "/../Log/";QDir dir(strDir);if (!dir.exists()){dir.mkdir(strDir);}strDir = QApplication::applicationDirPath() + "/../Log/" + QDateTime::currentDateTime().toString("yyyyMMdd");dir.setPath(strDir);if (!dir.exists()){dir.mkdir(strDir);}qDebug()<<strDir;};static void makesureIndex(){QString	strDir = QApplication::applicationDirPath() + "/../Log/" + QDateTime::currentDateTime().toString("yyyyMMdd");QDir dir(strDir);dir.setFilter(QDir::Files | QDir::NoDotAndDotDot);QFileInfoList list = dir.entryInfoList();foreach (auto var,list){QFileInfo fi(var.absoluteFilePath());if (fi.size() >= (1024 * 1024 * 10)){gIndex++;}}};
};#endif // CLOG_H

 

这篇关于Qt 日志之Qdebug 二次封装类的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/975715

相关文章

SpringBoot日志配置SLF4J和Logback的方法实现

《SpringBoot日志配置SLF4J和Logback的方法实现》日志记录是不可或缺的一部分,本文主要介绍了SpringBoot日志配置SLF4J和Logback的方法实现,文中通过示例代码介绍的非... 目录一、前言二、案例一:初识日志三、案例二:使用Lombok输出日志四、案例三:配置Logback一

SpringBoot中封装Cors自动配置方式

《SpringBoot中封装Cors自动配置方式》:本文主要介绍SpringBoot中封装Cors自动配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot封装Cors自动配置背景实现步骤1. 创建 GlobalCorsProperties

golang 日志log与logrus示例详解

《golang日志log与logrus示例详解》log是Go语言标准库中一个简单的日志库,本文给大家介绍golang日志log与logrus示例详解,感兴趣的朋友一起看看吧... 目录一、Go 标准库 log 详解1. 功能特点2. 常用函数3. 示例代码4. 优势和局限二、第三方库 logrus 详解1.

如何自定义Nginx JSON日志格式配置

《如何自定义NginxJSON日志格式配置》Nginx作为最流行的Web服务器之一,其灵活的日志配置能力允许我们根据需求定制日志格式,本文将详细介绍如何配置Nginx以JSON格式记录访问日志,这种... 目录前言为什么选择jsON格式日志?配置步骤详解1. 安装Nginx服务2. 自定义JSON日志格式各

SpringBoot项目使用MDC给日志增加唯一标识的实现步骤

《SpringBoot项目使用MDC给日志增加唯一标识的实现步骤》本文介绍了如何在SpringBoot项目中使用MDC(MappedDiagnosticContext)为日志增加唯一标识,以便于日... 目录【Java】SpringBoot项目使用MDC给日志增加唯一标识,方便日志追踪1.日志效果2.实现步

SQL Server清除日志文件ERRORLOG和删除tempdb.mdf

《SQLServer清除日志文件ERRORLOG和删除tempdb.mdf》数据库再使用一段时间后,日志文件会增大,特别是在磁盘容量不足的情况下,更是需要缩减,以下为缩减方法:如果可以停止SQLSe... 目录缩减 ERRORLOG 文件(停止服务后)停止 SQL Server 服务:找到错误日志文件:删除

Qt 中 isHidden 和 isVisible 的区别与使用小结

《Qt中isHidden和isVisible的区别与使用小结》Qt中的isHidden()和isVisible()方法都用于查询组件显示或隐藏状态,然而,它们有很大的区别,了解它们对于正确操... 目录1. 基础概念2. 区别清见3. 实际案例4. 注意事项5. 总结1. 基础概念Qt 中的 isHidd

Java导入、导出excel用法步骤保姆级教程(附封装好的工具类)

《Java导入、导出excel用法步骤保姆级教程(附封装好的工具类)》:本文主要介绍Java导入、导出excel的相关资料,讲解了使用Java和ApachePOI库将数据导出为Excel文件,包括... 目录前言一、引入Apache POI依赖二、用法&步骤2.1 创建Excel的元素2.3 样式和字体2.

QT移植到RK3568开发板的方法步骤

《QT移植到RK3568开发板的方法步骤》本文主要介绍了QT移植到RK3568开发板的方法步骤,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录前言一、获取SDK1. 安装依赖2. 获取SDK资源包3. SDK工程目录介绍4. 获取补丁包二

Qt把文件夹从A移动到B的实现示例

《Qt把文件夹从A移动到B的实现示例》本文主要介绍了Qt把文件夹从A移动到B的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录如何移动一个文件? 如何移动文件夹(包含里面的全部内容):如何删除文件夹:QT 文件复制,移动(