log4cplus学习笔记.docx
上传人:sy****28 上传时间:2024-09-13 格式:DOCX 页数:26 大小:43KB 金币:16 举报 版权申诉
预览加载中,请您耐心等待几秒...

log4cplus学习笔记.docx

log4cplus学习笔记.docx

预览

免费试读已结束,剩余 16 页请下载文档后查看

16 金币

下载此文档

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

/NUMPAGES26(一)log4cplus是C++编写的开源的日志系统,功能非常全面,用到自己开发的工程中会比较专业的,:),本文介绍了log4cplus基本概念,以及如何安装,配置。###简介###log4cplus是C++编写的开源的日志系统,前身是java编写的log4j系统.受ApacheSoftwareLicense保护。作者是TadE.Smith。log4cplus具有线程安全、灵活、以及多粒度控制的特点,通过将信息划分优先级使其可以面向程序调试、运行、测试、和维护等全生命周期;你可以选择将信息输出到屏幕、文件、NTeventlog、甚至是远程服务器;通过指定策略对日志进行定期备份等等。###下载###最新的log4cplus可以从以下网址下载http://log4cplus.sourceforge.net本文使用的版本为:1.0.2###安装###1.linux下安装tarxvzflog4cplus-x.x.x.tar.gzcdlog4cplus-x.x.x./configure--prefix=/where/to/installmakemakeinstall这里我采用缺省安装路径:/usr/local,下文如无特别说明,均以此路径为准。2.windows下安装不需要安装,有一个msvc6存放包括源代码和用例在内的开发工程(forVC6only),使用之前请先编译"log4cplus_dllclass"工程生成dll,或者编译"log4cplus_staticclass"工程生成lib.###使用前的配置###1.linux下的配置确保你的Makefile中包含/usr/local/lib/liblog4cplus.a(静态库)或-llog4cplus(动态库)即可,头文件在/usr/local/include/log4cplus目录下。对于动态库,要想正常使用,还得将库安装路径加入到LD_LIBRARY_PATH中,我一般是这样做的:以管理员身份登录,在/etc/ld.so.conf中加入安装路径,这里是/usr/local/lib,然后执行ldconfig使设置生效即可。2.windows下的配置将"log4cplus_dllclass"工程或"log4cplus_staticclass"工程的dsp文件插入到你的工程中,或者直接把两个工程编译生成的库以及头文件所在目录放到你的工程的搜索路径中,如果你使用静态库,请在你的工程中"project/setting/C++"的preprocessordefinitions中加入LOG4CPLUS_STATIC。###构成要素介绍###虽然功能强大,应该说log4cplus用起来还是比较复杂的,为了更好地使用它,先介绍一下它的基本要素。Layouts:布局器,控制输出消息的格式.Appenders:挂接器,与布局器紧密配合,将特定格式的消息输出到所挂接的设备终端(如屏幕,文件等等)。Logger:记录器,保存并跟踪对象日志信息变更的实体,当你需要对一个对象进行记录时,就需要生成一个logger。Categories:分类器,层次化(hierarchy)的结构,用于对被记录信息的分类,层次中每一个节点维护一个logger的所有信息。Priorities:优先权,包括TRACE,DEBUG,INFO,WARNING,ERROR,FATAL。本文介绍了log4cplus基本概念,以及如何安装,配置,下一篇将通过例子介绍如何使用log4cplus。(二)本文介绍了使用log4cplus有六个步骤,并提供了一些例子引导你了解log4cplus的基本使用。###基本使用###使用log4cplus有六个基本步骤:1.实例化一个appender对象2.实例化一个layout对象3.将layout对象绑定(attach)到appender对象4.实例化一个logger对象,调用静态函数:log4cplus::Logger::getInstance("logger_name")5.将appender对象绑定(attach)到logger对象,如省略此步骤,标准输出(屏幕)appender对象会绑定到logger6.设置logger的优先级,如省略此步骤,各种有限级的消息都将被记录下面通过一些例子来了解log4cplus的基本使用。〖例1〗cpp代码1./*严格实现步骤1-6,appender输出到屏幕,其中的布局格式和LogLevel后面会详细解释。*/2.#include<log4cplus\logger.h>1.#include<log4cplus\consolea