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

相关文章

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

python与QT联合的详细步骤记录

《python与QT联合的详细步骤记录》:本文主要介绍python与QT联合的详细步骤,文章还展示了如何在Python中调用QT的.ui文件来实现GUI界面,并介绍了多窗口的应用,文中通过代码介绍... 目录一、文章简介二、安装pyqt5三、GUI页面设计四、python的使用python文件创建pytho

QT实现TCP客户端自动连接

《QT实现TCP客户端自动连接》这篇文章主要为大家详细介绍了QT中一个TCP客户端自动连接的测试模型,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录版本 1:没有取消按钮 测试效果测试代码版本 2:有取消按钮测试效果测试代码版本 1:没有取消按钮 测试效果缺陷:无法手动停

基于Qt实现系统主题感知功能

《基于Qt实现系统主题感知功能》在现代桌面应用程序开发中,系统主题感知是一项重要的功能,它使得应用程序能够根据用户的系统主题设置(如深色模式或浅色模式)自动调整其外观,Qt作为一个跨平台的C++图形用... 目录【正文开始】一、使用效果二、系统主题感知助手类(SystemThemeHelper)三、实现细节

Qt实现文件的压缩和解压缩操作

《Qt实现文件的压缩和解压缩操作》这篇文章主要为大家详细介绍了如何使用Qt库中的QZipReader和QZipWriter实现文件的压缩和解压缩功能,文中的示例代码简洁易懂,需要的可以参考一下... 目录一、实现方式二、具体步骤1、在.pro文件中添加模块gui-private2、通过QObject方式创建

Qt QWidget实现图片旋转动画

《QtQWidget实现图片旋转动画》这篇文章主要为大家详细介绍了如何使用了Qt和QWidget实现图片旋转动画效果,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 一、效果展示二、源码分享本例程通过QGraphicsView实现svg格式图片旋转。.hpjavascript

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

flume系列之:查看flume系统日志、查看统计flume日志类型、查看flume日志

遍历指定目录下多个文件查找指定内容 服务器系统日志会记录flume相关日志 cat /var/log/messages |grep -i oom 查找系统日志中关于flume的指定日志 import osdef search_string_in_files(directory, search_string):count = 0

我在移动打工的日志

客户:给我搞一下录音 我:不会。不在服务范围。 客户:是不想吧 我:笑嘻嘻(气笑) 客户:小姑娘明明会,却欺负老人 我:笑嘻嘻 客户:那我交话费 我:手机号 客户:给我搞录音 我:不会。不懂。没搞过。 客户:那我交话费 我:手机号。这是电信的啊!!我这是中国移动!! 客户:我不管,我要充话费,充话费是你们的 我:可是这是移动!!中国移动!! 客户:我这是手机号 我:那又如何,这是移动!你是电信!!

JavaSE——封装、继承和多态

1. 封装 1.1 概念      面向对象程序三大特性:封装、继承、多态 。而类和对象阶段,主要研究的就是封装特性。何为封装呢?简单来说就是套壳屏蔽细节 。     比如:对于电脑这样一个复杂的设备,提供给用户的就只是:开关机、通过键盘输入,显示器, USB 插孔等,让用户来和计算机进行交互,完成日常事务。但实际上:电脑真正工作的却是CPU 、显卡、内存等一些硬件元件。