首先需要初始化QsLog:
Logger& logger = Logger::instance();
然后可以选择设置日志级别:
logger.setLoggingLevel(QsLogging::TraceLevel);
日志输出目的地一般有三个,分别是:输出到文件、输出到控制台和输出到处理函数。
输出到文件需要首先确定文件所在路径,然后设置将其输出到文件。
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());
示例:若为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);
DestinationPtr debugDestination(DestinationFactory::MakeDebugOutputDestination());
logger.addDestination(debugDestination);
DestinationPtr functorDestination(DestinationFactory::MakeFunctorDestination(&logFunction));
logger.addDestination(functorDestination);
输出到函数,该函数需要定义为如下类型:
typedef void (*LogFunction)(const QString &message, Level level);
DestinationPtr objectDestination(DestinationFactory::MakeFunctorDestination(window, SLOT(logSlot(QString,int))));
logger.addDestination(objectDestination);
然后编写相应的槽函数:
//槽函数
void logSlot(const QString &message, int level)
{
ui->textEdit->append(qPrintable(message));
}
打印日志示例如下:
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!";
析构掉:
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
};
可以通过setLoggingLevel()设置记录日志的级别。
void setLoggingLevel(Level newLevel)
示例:若设置为TraceLevel,则日志级别比TraceLevel高的都会输出,日志级别比其低的都会隐藏。
参考资源:https://www.freesion.com/article/3377866925