目录
一、QsLog使用的基本步骤
1.1 初始化
- 一、QsLog使用的基本步骤
- 1.1 初始化
- 1.2 设置日志输出目的地
- 1.2.1 输出到文件:
- 1.2.2 输出到控制台stdout:
- 1.2.3 输出到处理函数:
- 1.2.4 输出到Qt界面(如QTextEdit):
- 1.3 打印日志
- 1.4 销毁QsLog
- 二、设置打印行号
- 三、日志级别
首先需要初始化QsLog:
Logger& logger = Logger::instance();
然后可以选择设置日志级别:
logger.setLoggingLevel(QsLogging::TraceLevel);
1.2 设置日志输出目的地
日志输出目的地一般有三个,分别是:输出到文件、输出到控制台和输出到处理函数。
1.2.1 输出到文件:输出到文件需要首先确定文件所在路径,然后设置将其输出到文件。
const QString sLogPath(QDir(QApplication::applicationDirPath()).filePath("log.txt"));
DestinationPtr fileDestination(DestinationFactory::MakeFileDestination(
sLogPath, EnableLogRotation, MaxSizeBytes(512*1024), MaxOldLogCount(5)));
logger.addDestination(fileDestination);
函数原型:
static DestinationPtr MakeFileDestination(
const QString& filePath,
LogRotationOption rotation = DisableLogRotation,
const MaxSizeBytes &sizeInBytesToRotateAfter = MaxSizeBytes(),
const MaxOldLogCount &oldLogsToKeep = MaxOldLogCount());
- filePath: 日志文件名;
- rotation: 取值DisableLogRotation和EnableLogRotation,前者表示禁止日志文件分割,即日志始终往一个文件中写入;后者表示启用日志文件分割,此时sizeInBytesToRotateAfter和oldLogsToKeep参数才有意义;
- sizeInBytesToRotateAfter: 每个日志文件的字节数大小限制,即到达此大小后,自动新建文件,在新文件中进行写入;
- oldLogsToKeep: 旧日志文件保留(备份)个数,超过此数量,自动删除最久远文件,备份文件最多支持10个;
示例:若为2,则如下三个文件中内容,按照时间先后顺序排列为:log.txt.2->log.txt.1->log.txt,在log.txt中为最新日志,log.txt.1为次新,log.txt.2为最久远日志。若此时log.txt超过sizeInBytesToRotateAfter限制,则会发生log.txt.2被删除,log.txt.1被改名log.txt.2,log.txt被改名log.txt.1,新建log.txt。
代码示例:
//该文件可被拆分,当大小超5M时被拆分,最多10个旧文件(超过则自动删除最旧的)
DestinationPtr fileDestination(DestinationFactory::MakeFileDestination(sLogPath, EnableLogRotation, MaxSizeBytes(1024*1024*5), MaxOldLogCount(10)));
logger.addDestination(fileDestination);
1.2.2 输出到控制台stdout:
DestinationPtr debugDestination(DestinationFactory::MakeDebugOutputDestination());
logger.addDestination(debugDestination);
1.2.3 输出到处理函数:
DestinationPtr functorDestination(DestinationFactory::MakeFunctorDestination(&logFunction));
logger.addDestination(functorDestination);
输出到函数,该函数需要定义为如下类型:
typedef void (*LogFunction)(const QString &message, Level level);
1.2.4 输出到Qt界面(如QTextEdit):
DestinationPtr objectDestination(DestinationFactory::MakeFunctorDestination(window, SLOT(logSlot(QString,int))));
logger.addDestination(objectDestination);
然后编写相应的槽函数:
//槽函数
void logSlot(const QString &message, int level)
{
ui->textEdit->append(qPrintable(message));
}
1.3 打印日志
打印日志示例如下:
QLOG_INFO()
关注
打赏
最近更新
- 深拷贝和浅拷贝的区别(重点)
- 【Vue】走进Vue框架世界
- 【云服务器】项目部署—搭建网站—vue电商后台管理系统
- 【React介绍】 一文带你深入React
- 【React】React组件实例的三大属性之state,props,refs(你学废了吗)
- 【脚手架VueCLI】从零开始,创建一个VUE项目
- 【React】深入理解React组件生命周期----图文详解(含代码)
- 【React】DOM的Diffing算法是什么?以及DOM中key的作用----经典面试题
- 【React】1_使用React脚手架创建项目步骤--------详解(含项目结构说明)
- 【React】2_如何使用react脚手架写一个简单的页面?