log4cpp(log4cpp:logger有什么函数)

2024-06-11 17:56:56 40

log4cpp(log4cpp:logger有什么函数)

本文目录

log4cpp:logger有什么函数

C++日志库,log4cplus,log4cpp使用资料手册
1 下载log4cpp并解压。
2 打开\log4cpp-0.3.4b\msvc6\msvc6.dsw
编译log4cpp工程Release版。
3 将编译后的log4cpp.lib复制到VC的Lib目录中。
4 将头文件的目录log4cpp-0.3.4b\include\log4cpp\
复制到VC的Include目录.
(或者添加log4cpp-0.3.4b\include到VC的Include环境变量)
5 目标工程包含库
log4cpp.lib ws2_32.lib
复制到VC的Lib目录.
(要选择库连接方式相同的库)
6 包含头文件
日志记录
#include 《log4cplus/logger.h》
日志配置读取
#include 《log4cplus/consoleappender.h》
NDC
#include 《log4cplus/loglevel.h》
日志代码
每个类可以有自己的类别(log4cpp::Category),可以在配置文件中添加该类别并设置日志级别。
所有的log4cpp::Category都使用同一个Appender,不同的Category配置为不同的日志级别,就可以控制日志输出的范围。
一般只使用四个记录日志级:DEBUG,INFO,WARN,ERROR
如:
log4cpp::Category::getRoot().info(“Now run line %d“, __LINE__);
或使用非根类别
log4cpp::Category::getInstance(“MyCat“).info(“Now run line %d“, __LINE__);
使用流:
log4cpp::Category::getInstance(“main_cat“).infoStream()
《《 “This will show up as “
《《 1 《《 “ emergency message“
《《 log4cpp::CategoryStream::ENDLINE;
具体的函数说明见api文档.
7 读取配置代码
读取log配置文件,应在log4cpp静态成员初始化之后。
如在CXXXApp::InitInstance()中
try
{
log4cpp::PropertyConfigurator::configure(“log.ini“);
}
catch (log4cpp::ConfigureFailure e)
{
log4cpp::Category::getRoot().warn(e.what());
}

Log4cpp的概念

Log4cpp中的概念继承自log4j,最重要的是Category(种类)、Appender(附加目的地)和Layout(布局)三个概念,此外还有Priority(优先级)和NDC(嵌套的诊断上下文)等。
简言之,Category负责向日志中写入信息,Appender负责指定日志的目的地,Layout负责设定日志的格式,Priority被用来指定Category的优先级和日志的优先级, NDC则是一种用来区分不同场景中交替出现的日志的手段。
Log4cpp记录日志的原理如下:每个Category都有一个优先级,该优先级可以由setPriority方法设置,或者从其父Category中继承而来。每条日志也有一个优先级,当Category记录该条日志时,若日志优先级高于Category的优先级时,该日志被记录,否则被忽略。系统中默认的优先级等级如下:
typedef enum ...{EMERG = 0,
FATAL = 0,
ALERT = 100,
CRIT = 200,
ERROR = 300,
WARN = 400,
NOTICE = 500,
INFO = 600,
DEBUG = 700,
NOTSET = 800
} PriorityLevel;
注意:取值越小,优先级越高。 例如一个Category的优先级为101,则所有EMERG、FATAL、ALERT日志都可以记录下来,而其他则不能。
Category、Appender和Layout三者的关系如下:系统中可以有多个Category,它们都是继承自同一个根,每个Category负责记录自己的日志;每个Category可以添加多个Appender,每个Appender指定了一个日志的目的地,例如文件、字符流或者Windows日志,当Category记录一条日志时,该日志被写入所有附加到此Category的Appender;每个Append都包含一个Layout,该Layout定义了这个Appender上日志的格式。
重温前面的HelloWorld程序,可以发现其流程如下:
1. 创建一个Appender,并指定其包含的Layout;
2. 从系统中得到Category的根,将Appender添加到该Category中;
3. 设置Category的优先级;
4. 记录日志;
5. 关闭Category。
下面,我们按照Layout、Appender、Category、NDC的顺序来依次介绍这些概念并给出例子。

Log4cpp的编译方法

让我们从一个简单的例子开始,该例子将两条日志信息写入字符串流,该流会在标准控制台cout上输出,项目的名称是HelloLog4Cpp:
#include 《iostream》
#include log4cpp/Category.hh
#include log4cpp/OstreamAppender.hh
#include log4cpp/BasicLayout.hh
#include log4cpp/Priority.hh
using namespace std;
int main(int argc, char* argv)
{
log4cpp::OstreamAppender* osAppender = new log4cpp::OstreamAppender(osAppender, &cout);
osAppender-》setLayout(new log4cpp::BasicLayout());
log4cpp::Category& root = log4cpp::Category::getRoot();
root.addAppender(osAppender);
root.setPriority(log4cpp::Priority::DEBUG);
root.error(Hello· log4cpp in a Error Message!);
root.warn(Hello ·log4cpp in a Warning Message!);
log4cpp::Category::shutdown();
return 0;
}
要顺利编译运行还有两个地方需要设置,其一是引入的库中加上log4cppD.lib(debug版dll库的引入文件),即在头文件处加上#pragma comment(lib, log4cppD.lib);其二是将C/C++的Code Generation中的Use Runtime library设置为“Debug Multithreaded DLL”。 设置完成后编译运行结果如下:
1248337987 ERROR : Hello· log4cpp in a Error Message!
1248337987 WARN : Hello· log4cpp in a Warning Message!
以上两条日志格式很简陋,要设置合乎心意的日志格式,请参考后续的PatternLayout章节。

Log4cpp的下载安装

2.1 下载
下载版本0.3.5rc3,这个版本目前是最稳定的,版本1.0在VC中表现不稳定。下载后的包名字为:log4cpp-0.3.5rc3.tar.gz(源代码包)和log4cpp-docs-0.3.5rc3.tar.gz(文档压缩包)。将它们解压后放入D盘。
2.2 在VC6中编译Log4cpp
进入D:\log4cpp-0.3.5rc3\msvc6目录,打开VC6的工作区msvc6.dsw,将其中的工程都删除,只保留log4cpp和log4cppDLL两个工程。分别编译它们的Debug和Release版本。
在VC6中编译Log4cpp会报错,其实只有一个错误,即不能在头文件中定义变量,同时给变量赋默认值。修改方法如下:将头文件Priority.hh中的这一行:
static const int MESSAGE_SIZE = 8;
改为:
static const int MESSAGE_SIZE;
并在Priority.cpp中的所有include语句后加上:const int log4cpp::Priority::MESSAGE_SIZE = 8;
编译链接成功后会得到log4cppD.dll、log4cppD.lib(Debug版的dll和lib文件)和log4cpp.dll、log4cpp.lib(Release版的dll和lib文件)。新建目录D:\log4cpp-0.3.5rc3\lib,将以上四个文件拷贝到该目录下。 在VC中添加设置lib和include路径。
将D:\log4cpp-0.3.5rc3\lib加入系统的Path路径中。

Log4cpp的布局

首先回顾一下HelloWorld的日志格式,它使用了最简单的BasicLayout:   1248337987 ERROR : Hello log4cpp in a Error Message!   1248337987 WARN : Hello log4cpp in a Warning Message!
上面的日志格式还可以,但显然不是许多程序员心中理想的格式,许多人理想的格式应该是这样的:   2009-07-24 15:59:55,703: INFO infoCategory : system is running   2009-07-24 15:59:55,703: WARN infoCategory : system has a warning   2009-07-24 15:59:55,703: ERROR infoCategory : system has a error, cant find a file   2009-07-24 15:59:55,718: FATAL infoCategory : system has a fatal error, must be shutdown   2009-07-24 15:59:55,718: INFO infoCategory : system shutdown, you can find some information in system log
要获得上面的格式,必须使用比BasicLayout复杂的PatternLayout,而且要花一个小时来熟悉一下PatternLayout的格式定义方式,如果你认为值得的话。 5.1 PatternLayout
在介绍PatternLayout以前,首先来看看log4cpp中所有的Layout子类(Layout本身是个虚类),一共三个:BasicLayout、PatternLayout和SimpleLayout,其中SimapleLayout并不建议使用,而BaiscLayout过于简单,因此如果程序员不自己扩展Layout的话,就只能使用PatternLayout了,值得庆幸的是,PatternLayout还是比较好用的。
PatternLayout使用setConversionPattern函数来设置日志的输出格式。该函数的声明如下:   void log4cpp::PatternLayout::setConversionPattern ( const std::string & conversionPattern ) throw (ConfigureFailure)
其中参数类型为std::string,类似于C语言中的printf,使用格式化字符串来描述输出格式,其具体含义如下:   %c category;   %d 日期;日期可以进一步的设置格式,用花括号包围,例如%d{%H:%M:%S,%l} 或者 %d{%d %m %Y %H:%M:%S,%l}。如果不设置具体日期格式,则如下默认格式被使用“Wed Jan 02 02:03:55 1980”。日期的格式符号与ANSI C函数strftime中的一致。但增加了一个格式符号%l,表示毫秒,占三个十进制位。   %m 消息;   %n 换行符,会根据平台的不同而不同,但对于用户透明;   %p 优先级;   %r 自从layout被创建后的毫秒数;   %R 从1970年1月1日0时开始到目前为止的秒数;   %u 进程开始到目前为止的时钟周期数;   %x NDC。
因此,要得到上述的理想格式,可以将setConversionPattern的参数设置为“%d: %p %c %x: %m%n”,其具体含义是“时间: 优先级 Category NDC: 消息 换行”。

log4cpp,log4cplus,log4cxx这几个包之间是什么关系

Log4cxx需要依赖于APR。
Log4cpp较log4c移植性稍差些。
Log4c基本上都是一些纯c的东西,移植性比其他二者都要好
log4cplus: 简洁, 下载的包编译顺利, 测试例子也能顺利运行。
log4cxx: 臃肿, 需要引用apr(Apache Portable Runtime), 最痛苦的是老是编译不了。
log4cpp: 落后, 最后更新于2007年,而且下载的包不完整。

Log4cpp的优点

Log4cpp是个基于LGPL的开源项目,移植自Java的日志处理跟踪项目log4j,并保持了API上的一致。其类似的支持库还包括Java(log4j),C++(log4cpp、log4cplus),C(log4c),python(log4p)等。
Log4cpp有如下优点:
1. 提供了可扩展的多种日志记录方式;
2. 提供了NDC(嵌套诊断上下文),可用于多线程、多场景的跟踪调试;
3. 提供了完整的日志动态优先级控制,可随时调整需要记录的日志优先级;
4. 可通过配置文件完成所有配置并动态加载;
5. 性能优秀,内存占用小,经过编译后的log4cpp.dll大小仅有160kb;
6. 代码级的平台无关性,Log4cpp源代码经过编译后,适用于大多数主流的操作系统和开发工具;
7. 概念清晰,学习和使用方便,熟练程序员一天之内即可很好地应用log4cpp进行开发

谁能提供几个与log4cpp相关的简单例子做个参考啊,要向下面一样格式的分数不是问题,急求啊!!!!!

你不会是在找这个吧?
#include《iostream》
#include《log4cpp/Category.hh》
#include《log4cpp/OstreamAppender.hh》
#include《log4cpp/Priority.hh》
#include《log4cpp/PatternLayout.hh》
using namespace std;
int main(int argc,char* argv)
{
log4cpp::OstreamAppender* osAppender = new log4cpp::OstreamAppender(“osAppender“,&cout);
log4cpp::PatternLayout* pLayout = new log4cpp::PatternLayout();
pLayout-》setConversionPattern(“%d: %p %c %x: %m%n“);
osAppender-》setLayout(pLayout);

log4cpp::Category& root =log4cpp::Category::getRoot();
log4cpp::Category& infoCategory =root.getInstance(“infoCategory“);
infoCategory.addAppender(osAppender);
infoCategory.setPriority(log4cpp::Priority::INFO);

infoCategory.info(“system isrunning“);
infoCategory.warn(“system has awarning“);
infoCategory.error(“system hasa error, can’t find a file“);
infoCategory.fatal(“system hasa fatal error,must be shutdown“);
infoCategory.info(“systemshutdown,you can find some information in systemlog“);
log4cpp::Category::shutdown();
return 0;
}
其运行结果即如下所示:
2009-07-2415:59:55,703: INFO infoCategory : system is running
2009-07-2415:59:55,703: WARN infoCategory : system has a warning
2009-07-2415:59:55,703: ERROR infoCategory : system has a error, can’t find afile
2009-07-2415:59:55,718: FATAL infoCategory : system has a fatal error, mustbe shutdown
2009-07-2415:59:55,718: INFO infoCategory : system shutdown, you can findsome information in system log
参考网址:http://blog.csdn.net/kingskyleader/article/details/7320826

vs2008怎么搭建log4cpp

vs2008 、vs2005下 std::ifstream中不支持中文,是因为在vs2008 、vs2005 下,默认传入的 unicode 字符集 ,而一般开发的时候 大多数使用的多字节字符集,所以会导致出错 。
1、使用C语言的函数设置为中文运行环境
setlocale(LC_ALL, “Chinese-simplified“);
2、使用STL函数设置为系统语言环境
std::locale::global(std::locale(““));
3. 或者 直接 修改 log4cpp 的 参数,直接传入的是 宽字节 。

log4cpp(log4cpp:logger有什么函数)

本文编辑:admin
log4cpp ,cpp ,ogg

更多文章:


怎么用电话订票?怎么买飞机票网上订票步骤

怎么用电话订票?怎么买飞机票网上订票步骤

本文目录怎么用电话订票怎么买飞机票网上订票步骤火车票订票的5种方式分别是什么买飞机票网上订票步骤是什么在网上怎么订飞机票网上订飞机票怎么订中国官方的飞机票订购软件是什么网上怎么订票如何买火车票网上订票怎么查订票信息怎么用电话订票电话订票需要

2024年6月6日 20:03

wow火鸡捉贼者怎么做?魔兽世界火鸡终结者怎么做,详细点

wow火鸡捉贼者怎么做?魔兽世界火鸡终结者怎么做,详细点

本文目录wow火鸡捉贼者怎么做魔兽世界火鸡终结者怎么做,详细点火鸡终结者怎么做火鸡终结者成就怎么做魔兽世界把目标变成火鸡的玩具叫什么名字怎么获得火鸡终结者你们怎么做的啊wow火鸡捉贼者怎么做魔兽世界火鸡捉贼者尽快猎杀足够的野生火鸡来获得对火

2024年6月5日 20:39

3dwarehouse(3dwarehouse怎么调整大小)

3dwarehouse(3dwarehouse怎么调整大小)

本文目录3dwarehouse怎么调整大小3Dwarehouse怎么导入flexsim3dwarehouse在SU组件缩小3d+warehouse为什么登不上去3dwarehouse怎么调整大小两种方法。1、3dwarehouse调整大小可

2023年5月15日 10:00

狂野西部 生死同盟(狂野西部的《生死同盟》)

狂野西部 生死同盟(狂野西部的《生死同盟》)

大家好,关于狂野西部 生死同盟很多朋友都还不太明白,不过没关系,因为今天小编就来为大家分享关于狂野西部的《生死同盟》的知识点,相信应该可以解决大家的一些困惑和问题,如果碰巧可以解决您的问题,还望关注下本站哦,希望对各位有所帮助!本文目录狂野

2024年9月1日 19:40

求推荐言情类穿越修仙师徒恋小说!不要仙侠奇缘之花千骨?谁能帮咱介绍几本修真小说啊! 咱在这先谢谢了!

求推荐言情类穿越修仙师徒恋小说!不要仙侠奇缘之花千骨?谁能帮咱介绍几本修真小说啊! 咱在这先谢谢了!

本文目录求推荐言情类穿越修仙师徒恋小说!不要仙侠奇缘之花千骨谁能帮咱介绍几本修真小说啊! 咱在这先谢谢了!有哪些小说是主角一出场就很强的玄幻小说小说主角林宏月苏月琴是哪部小说仙侠情缘三部曲分别是什么求推荐言情类穿越修仙师徒恋小说!不要仙侠奇

2024年6月6日 19:32

万年历下载免费安装 老黄历(老黄历下载安装,如何在手机上安装老黄历)

万年历下载免费安装 老黄历(老黄历下载安装,如何在手机上安装老黄历)

本文目录老黄历下载安装,如何在手机上安装老黄历万年历老黄历下载,下载万年历黄历带农历万年黄历下载手机版,万年历黄历怎么下载万年黄历下载手机版,万年历黄历的iOS软件信息万年历老黄历下载安装官方版,老黄历万年历下载老黄历万年历下载安装,万年历

2024年7月23日 21:09

360磁盘痕迹清理器能彻底清除USB记录吗U盘记录?电脑的磁盘空间在哪里清理

360磁盘痕迹清理器能彻底清除USB记录吗U盘记录?电脑的磁盘空间在哪里清理

本文目录360磁盘痕迹清理器能彻底清除USB记录吗U盘记录电脑的磁盘空间在哪里清理磁盘清理怎么打开360磁盘痕迹清理器能彻底清除USB记录吗U盘记录360磁盘痕迹清除器是360安全中心发布的一款磁盘痕迹擦除工具,用于防止计算机中已经被回收站

2023年11月22日 13:00

谁知道有关南北朝的小说 要着重于历史军事,争霸天下的?求好看严谨的穿越小说~

谁知道有关南北朝的小说 要着重于历史军事,争霸天下的?求好看严谨的穿越小说~

本文目录谁知道有关南北朝的小说 要着重于历史军事,争霸天下的求好看严谨的穿越小说~天命传奇是一款什么样的游戏传奇推广加好友用什么行啊,快速高效的宋太祖问赵恒“天子好作否”对曰:“由天命耳”后继承皇位,你怎么看谁知道有关南北朝的小说 要着重于

2024年6月5日 21:56

三星gts7572(三星手机GTs7572好吗)

三星gts7572(三星手机GTs7572好吗)

本文目录三星手机GTs7572好吗三星gts7572太慢怎么办三星GTs7572能不能用移动的手机卡上网三星gts7572如何root三星gts7572支持4g吗三星GTs7572三星GTS7572 系统4.1.2 怎样升级三星gts757

2024年7月17日 05:29

中国好声音第四季下载(中国好声音第四季冠军是谁)

中国好声音第四季下载(中国好声音第四季冠军是谁)

本文目录中国好声音第四季冠军是谁哪个网站可以看中国好声音第四季一,二,三,四季中国好声音冠军是谁中国好声音第四季冠军是谁《中 国 好 声 音》第四季的冠军是张磊张磊,1981年10月7日出生于黑龙江省牡丹江市,中国内地男歌手、演员。张磊,1

2023年6月30日 11:20

有什么3D游戏(网游和单机)的女角色穿着性感和火辣的,最好是身材凹凸有致的那种,介绍一下!!?性感海滩4这个游戏 那个海滨的酒吧,想喝酒喝得太多了吧这个任务怎么过 不会啊 而且地图都跑遍了

有什么3D游戏(网游和单机)的女角色穿着性感和火辣的,最好是身材凹凸有致的那种,介绍一下!!?性感海滩4这个游戏 那个海滨的酒吧,想喝酒喝得太多了吧这个任务怎么过 不会啊 而且地图都跑遍了

这篇文章给大家聊聊关于性感沙滩0,以及有什么3D游戏(网游和单机)的女角色穿着性感和火辣的,最好是身材凹凸有致的那种,介绍一下!!对应的知识点,希望对各位有所帮助,不要忘了收藏本站哦。本文目录有什么3D游戏(网游和单机)的女角色穿着性感和火

2024年8月31日 15:40

android小游戏(通过视频可以玩的互动游戏)

android小游戏(通过视频可以玩的互动游戏)

本文目录通过视频可以玩的互动游戏android系统7.0寸的平板,有哪些好玩的游戏推荐好玩的小于10mb的android小游戏推荐想要用安卓系统写一个小游戏,需要学习哪些知识通过视频可以玩的互动游戏可以。很多玩家十分喜欢玩游戏,轻松互动,还

2024年6月6日 21:15

多普达手机动感大挪移软件有谁会用?使用动感大挪移后如何恢复

多普达手机动感大挪移软件有谁会用?使用动感大挪移后如何恢复

本文目录多普达手机动感大挪移软件有谁会用使用动感大挪移后如何恢复多普达手机动感大挪移软件有谁会用楼上的回答都不太准啊。。。动感大挪移是这样使用的,首先你要确保你的手机可以和计算机连接,然后建立好手机gprs网络连接(在电脑上连接),然后打开

2023年7月12日 19:40

洛克王国4399小游戏(在4399小游戏中中进入洛克王国会被盗号吗)

洛克王国4399小游戏(在4399小游戏中中进入洛克王国会被盗号吗)

“洛克王国4399小游戏”相关信息最新大全有哪些,这是大家都非常关心的,接下来就一起看看洛克王国4399小游戏(在4399小游戏中中进入洛克王国会被盗号吗)!本文目录在4399小游戏中中进入洛克王国会被盗号吗4399洛克王国我可以在手机上玩

2024年7月19日 06:20

dedecms企业模板(想建个企业站是用dedecms还是用sdcms呢,asp的空间和sdcms的模板都买好了,却又犹豫了)

dedecms企业模板(想建个企业站是用dedecms还是用sdcms呢,asp的空间和sdcms的模板都买好了,却又犹豫了)

本文目录想建个企业站是用dedecms还是用sdcms呢,asp的空间和sdcms的模板都买好了,却又犹豫了dedecms主要提供什么功能,对一个网站起到哪些的改进,是提供前台还是后台的模板织梦dedecms 怎么用自己的模板想建个企业站是

2024年7月14日 01:20

丧尸围城4钥匙怎么用?丧尸围城4加点

丧尸围城4钥匙怎么用?丧尸围城4加点

本文目录丧尸围城4钥匙怎么用丧尸围城4加点丧尸围城4怎么剧情联机 丧尸围城4可以剧情联机吗丧尸围城4怎么快速旅行 丧尸围城4如何快速旅行丧尸围城4挖掘需要什么工具丧尸围城4怎么联机 丧尸围城4联机的方法丧尸围城4怎么扔雷 丧尸围城4如何扔雷

2024年7月18日 09:46

徐州自古就是兵家战争之地,谁能告诉我徐州为什么是兵家必争之地呢?也门这个国家地理位置到底有多重要,为何命中注定成为代理人战争的发生地

徐州自古就是兵家战争之地,谁能告诉我徐州为什么是兵家必争之地呢?也门这个国家地理位置到底有多重要,为何命中注定成为代理人战争的发生地

本文目录徐州自古就是兵家战争之地,谁能告诉我徐州为什么是兵家必争之地呢也门这个国家地理位置到底有多重要,为何命中注定成为代理人战争的发生地帮忙翻译下!此乃四分五裂战争之地,难以自安,不如及道路尚通,举宗东黎阳阪泉之战与涿鹿的战争之地为何相同

2023年8月29日 12:40

六级分数计算器(英语四级分数如何换算多少分算过关卷面成绩就是最终成绩吗)

六级分数计算器(英语四级分数如何换算多少分算过关卷面成绩就是最终成绩吗)

本文目录英语四级分数如何换算多少分算过关卷面成绩就是最终成绩吗英语六级怎么算分的啊大学英语六级口语考试考什么这样的六级分数大概考研英语里能考多少分啊如果英语四级题目没做完,该怎么算分英语四级评分每年都不一样吗 四级评分标准是什么2015英语

2023年8月28日 14:40

厦门市快乐淘一族商贸有限公司怎么样?北京快乐淘科技有限公司怎么样

厦门市快乐淘一族商贸有限公司怎么样?北京快乐淘科技有限公司怎么样

大家好,如果您还对快乐淘不太了解,没有关系,今天就由本站为大家分享快乐淘的知识,包括厦门市快乐淘一族商贸有限公司怎么样的问题都会给大家分析到,还望可以解决大家的问题,下面我们就开始吧!本文目录厦门市快乐淘一族商贸有限公司怎么样北京快乐淘科技

2024年9月6日 07:30

cad2008安装序列号(CAD2008激活码)

cad2008安装序列号(CAD2008激活码)

大家好,如果您还对cad2008安装序列号不太了解,没有关系,今天就由本站为大家分享cad2008安装序列号的知识,包括CAD2008激活码的问题都会给大家分析到,还望可以解决大家的问题,下面我们就开始吧!本文目录CAD2008激活码求ca

2024年7月14日 09:59

近期文章

本站热文

4008827777转人工客服(4008827777饿了么怎么转人工电话)
2024-07-23 14:41:37 浏览:501
标签列表

热门搜索