日志记录工具:log4cpp
一、主要工具类
- 日志系统,就是将用户指定的信息,按照一定的格式,存储到一个指定的区域。
- 根据面向对象的思想,可以抽象出一个执行日志记录的主体Category,该主体用于执行日志的开始,结束以及记录。
- 而如何执行日志记录、这些功能也可以单独抽象出一个类,作为Category的一种属性。
log4cpp的开发主要使用以下四个工具类
-
Category类。 执行日志记录任务的主体,其构造函数是protect类型,默认有一个root的Category实例,其他的Category实例均从root衍生出来。使用log4cpp必须有一个Category实例。
-
Appender类。Appender类用于描述日志如何输出,例如使用什么格式输出以及日志输出到哪里。其中使用什么格式输出,是通过Layout类来进行实现的。Appender是一个基类,常用的Appender有FileAppender、OstreamAppender以及RollingFileAppender。
-
Layout类。用于描述日志输出的格式。
-
Priority。用于过滤日志信息。Priority类根据设置的优先级的不同,会过滤掉相应的优先级低于(数值越低优先级越高)当前Category实例设置成的优先级的记录。
二、使用流程
-
由于log4cpp是以Category类为基础进行日志操作。所以可以先定义一个Category类的变量。
-
如果需要将Category实例的属性补充完整,需要使用Appender类,所以第二步可以定义一个Appender类。
-
Appender类需要使用描述输出的格式,因此需要定义一个Layout类来设置输出格式
-
Layout类设定完毕后->完善Appender类->完善Category类
-
设定Category实例的优先级
-
利用Category实例进行日志记录、
-
使用Category::shutdown()来结束日志记录,销毁各个对象。
三、使用单例模式进行简易封装
- 1.将日志消息记录到标准输出cout 以及回滚文件中
- 2.实例创建成功后只需要使用相应的函数进行打印结果即可,
- 3.默认格式会打印所在文件,行号,函数,以及消息信息
//使用的头文件
#include <iostream>
#include <string>
#include <sstream>
#include <log4cpp/Category.hh>
#include <log4cpp/Appender.hh>
#include <log4cpp/FileAppender.hh>
#include <log4cpp/OstreamAppender.hh>
#include <log4cpp/RollingFileAppender.hh>
#include <log4cpp/Layout.hh>
#include <log4cpp/PatternLayout.hh>
using namespace log4cpp;
using namespace std;
//类结构的声明
class MLog{
public:
static MLog* logCntl(const bool flag,const string& FileName,
const size_t& fileSize = 10*1024*1024,const int& RollingFileNum = 10,
const int& PRIORITY = Priority::DEBUG);
int getPriority()const;
void setpriority(int PRIORITY);
void logInfo(const string& msg)const;
void