Qt第三方日志库QsLog基本语法介绍

一、QsLog使用的基本步骤

1.1 初始化

首先需要初始化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() << "Program started";
    QLOG_TRACE() << "Here's a" << QString::fromUtf8("trace") << "message";
    QLOG_DEBUG() << "Here's a" << static_cast<int>(QsLogging::DebugLevel) << "message";
    QLOG_WARN()  << "Uh-oh!";
    QLOG_ERROR() << "An error has occurred";
    QLOG_FATAL() << "Fatal error!";

1.4 销毁QsLog

析构掉:

QsLogging::Logger::destroyInstance();

ok,以上四步便是QsLog的全部步骤了。

二、设置打印行号

在QsLog.pri文件中添加如下语句:

DEFINES += QS_LOG_LINE_NUMBERS

打开此宏定义,重新编译,即可打印带源文件名称和行号的日志。如下:
在这里插入图片描述

三、日志级别

QsLog支持六个日志级别,优先级从低到高依次为:Trace、Debug、Info、Warn、Error、Fatal、Off。如下:

enum Level
{
    TraceLevel = 0,
    DebugLevel,
    InfoLevel,
    WarnLevel,
    ErrorLevel,
    FatalLevel,
    OffLevel
};
  • Trace:跟踪,最低等级的,用于打开所有日志记录;
  • Debug:调试,打印一些细粒度调试运行信息。
  • Info:信息,打印粗粒度信息,突出强调程序的运行过程。打印一些感兴趣或者重要的信息,可用于环境中输出程序运行的一些重要信息,但不能滥用,避免打印过多日志;
  • Warn:警告,表明会出现潜在错误的情形,有些信息不是错误信息,但是也要给程序员的一些提示。
  • Error:错误,指出虽然发生错误,但仍然不影响系统的继续运行。打印错误和异常信息;
  • Fatal:致命的,发生严重错误,将导致应用程序的退出。这个级别比较高,程序直接停止运行了;
  • Off:最高等级的,用于关闭所有日志记录。

可以通过setLoggingLevel()设置记录日志的级别。

void setLoggingLevel(Level newLevel)

示例:若设置为TraceLevel,则日志级别比TraceLevel高的都会输出,日志级别比其低的都会隐藏。


参考资源:https://www.freesion.com/article/3377866925

Qt中,第三方可以通过静态编译和动态编译两种方式进行使用。 1. 静态编译:静态编译是指将第三方的代码编译成静态(.a或.lib文件),并将静态链接到应用程序中,生成一个单独的可执行文件。这种方式需要在.pro文件中指定要链接的静态,例如: ``` LIBS += -lmylib ``` 其中,`mylib`是要链接的静态名字。 静态编译的优点是运行时不需要动态加载第三方,提高了启动速度和效率。但缺点是可执行文件较大,不易扩展和更新。 2. 动态编译:动态编译是指将第三方的代码编译成动态(.dll或.so文件),并在运行时通过libloaderapi函数手动加载动态,并通过QLibrary类获取动态中的函数地址,然后直接调用该函数。这种方式需要在代码中显式加载动态,例如: ``` QLibrary mylib("mylib.dll"); mylib.load(); ``` 然后通过QLibrary的resolve方法获取函数地址,例如: ``` void (*myFunc)() = (void (*)()) mylib.resolve("myFunc"); ``` 其中,`myFunc`是要调用的函数名。 动态编译的优点是灵活性高,可以根据实际需要动态加载和卸载第三方,便于扩展和更新。但缺点是运行时需要动态加载第三方,影响了启动速度和效率。 需要注意的是,在使用第三方时,需要遵循一些规范和最佳实践,以确保正确性和安全性。特别是在获取函数地址时,需要确保函数名的正确性和类型匹配,否则可能导致运行时错误和安全漏洞。同时,在编译和链接时,需要遵循第三方的使用规范,以确保文件的正确链接和使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wendy_ya

您的鼓励将是我创作的最大动力~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值