当前位置: 首页 > 编程日记 > 正文

Log4cplus1.04的使用

首先,从http://sourceforge.net/projects/log4cplus/files/log4cplus-stable/下载最新的版本,解压缩,用vs2008打开msvc8文件夹下的log4cplus.sln,并按照提示转换。在Solution Configurations下拉列表框中,会有Debug、Debug_Unicode、Release、Release_Unicode四种形式,分别选择进行编译,选中Solution ‘log4cplus’,点击Biuld Solution,会在每种形式下成功编译17个工程文件。在msvc8/Win32下的文件夹中生成相应的库文件和exe执行文件。

将相应的库和头文件包含到相应的目录中即可应用,若不想改变头文件中包含的头文件设置,还需自己创建一个项目属性表。

基本元素:

Logger:解决了在哪里使用日志的问题,日志模块,程序中唯一一个必须要使用的模块;

Appenders:解决了将日志信息最终输出到哪里去的问题,如控制台、文件、网络等;

Layout:解决了如何输出的问题,格式化输出信息;

Filter:解决了最终哪些类型的信息需要输出,比如DEBUG、WARR、TRACE、INFO、ERROR等;

一般步骤:

(1)、生成Appender对象;

(2)、生成Layout对象,并绑定到Appender(可选);

(3)、生成Logger对象;

(4)、设置Logger优先级(可选);

(5)、将需要关联Logger的Appender添加到Logger上;

(6)、使用Logger输出信息,所有大于设定的优先级的信息,并在所有挂接在该Logger对象上的Appender上以相应的Layout设定的格式显示出来;

LogLevels:TRACE、DEBUG、INFO、WARN、ERROR、FATAL;

Layout:BasicLayout、TTCCLayout、PatternLayout;

Appenders:ConsoleAppender、FileAppender、RollingFileAppender、DailyRollingFileAppender、SyslogAppender、NTEventLogAppender、SocketAppender、Win32DebugAppender;

Filter:DenyAllFilter、LogLevelMatchFilter、LogLevelRangeFilter、StringMatchFilter;

// TestLog4cplus.cpp : Defines the entry point for the console application.

//

#include "stdafx.h"

#include <string>

#include <log4cplus/logger.h>//定义Log对象

#include <log4cplus/consoleappender.h>//输出到控制台

#include <log4cplus/fileappender.h>//输出到文件

#include <log4cplus/layout.h>//输出格式

using namespace std;

using namespace log4cplus;

using namespace log4cplus::helpers;

int _tmain(int argc, _TCHAR* argv[])

{

string strLogName1 = "E:\\Log4cplus\\TestLog1.log";

string strLogName2 = "E:\\Log4cplus\\TestLog2.log";

//定义控制台Appender

SharedAppenderPtr pConsoleAppender(new ConsoleAppender());

//定义文件Appender

SharedAppenderPtr pFileAppender(new FileAppender(LOG4CPLUS_TEXT(strLogName1), LOG4CPLUS_FSTREAM_NAMESPACE::ios::app, true));

SharedAppenderPtr pRollingFileAppender(new RollingFileAppender(LOG4CPLUS_TEXT(strLogName2), 1024*1024, 1, true));

//定义Layout,并绑定到Appender上

//pConsoleAppender->setLayout(std::auto_ptr<Layout>(new SimpleLayout()));

//pFileAppender->setLayout(std::auto_ptr<Layout>(new SimpleLayout()));

//pRollingFileAppender->setLayout(std::auto_ptr<Layout>(new SimpleLayout()));

//pConsoleAppender->setLayout(std::auto_ptr<Layout>(new TTCCLayout()));

//pFileAppender->setLayout(std::auto_ptr<Layout>(new TTCCLayout()));

//pRollingFileAppender->setLayout(std::auto_ptr<Layout>(new TTCCLayout()));

//log4cplus::tstring pattern = LOG4CPLUS_TEXT("%d{%m/%d/%y %H:%M:%S,%Q} [%t] %-5p %c{2} %%%x%% - %m [%l]%n");

//log4cplus::tstring pattern = LOG4CPLUS_TEXT("%D{%c} %p %% %m %% [%l]%n");//%D显示本地时间、%d显示标准时间

log4cplus::tstring pattern = LOG4CPLUS_TEXT("%D{%Y/%m/%d %X} %p %% %m %% [%l]%n");

pConsoleAppender->setLayout(std::auto_ptr<Layout>(new PatternLayout(pattern)));

pFileAppender->setLayout(std::auto_ptr<Layout>(new PatternLayout(pattern)));

pRollingFileAppender->setLayout(std::auto_ptr<Layout>(new PatternLayout(pattern)));

//定义Logger

Logger pTestLogger = Logger::getInstance(LOG4CPLUS_TEXT("LoggerName"));

//设置Logger优先级

//pTestLogger.setLogLevel(ALL_LOG_LEVEL);

//pTestLogger.setLogLevel(DEBUG_LOG_LEVEL);

pTestLogger.setLogLevel(INFO_LOG_LEVEL);

//pTestLogger.setLogLevel(WARN_LOG_LEVEL);

//pTestLogger.setLogLevel(ERROR_LOG_LEVEL);

//将需要关联Logger的Appender添加到Logger上

pTestLogger.addAppender(pConsoleAppender);

pTestLogger.addAppender(pFileAppender);

pTestLogger.addAppender(pRollingFileAppender);

//输出日志信息

LOG4CPLUS_INFO(pTestLogger, "this is a info log...");

LOG4CPLUS_DEBUG(pTestLogger, "this is a debug log...");

LOG4CPLUS_ERROR(pTestLogger, "this is a error log...");

LOG4CPLUS_WARN(pTestLogger, "this is a warn log...");

return 0;

}

参考文献:

1、  http://log4cplus.sourceforge.net/

2、  http://pyhcx.blog.51cto.com/713166/143549

3、  http://www.cppblog.com/tx7do/articles/11715.html

4、  http://www.cppblog.com/API/archive/2011/04/02/143275.html

5、  http://msdn.microsoft.com/zh-cn/library/5k4a0033(v=VS.90).aspx

6、  http://www.cnblogs.com/kenter/archive/2011/09/05/2167201.html

相关文章:

FRVT赛程全纪录:格灵深瞳全球排名前五

作者 | 张德兵&#xff0c;格灵深瞳首席科学家&算法部负责人来源 | 转载自知乎张德兵最近两个月&#xff0c;格灵深瞳首席科学家&算法部负责人张德兵与算法团队参加了全球人脸识别算法测试(FRVT、Face Recognition Vendor Test)。虽然是第一次参加此比赛&#xff0c;格…

反转比特位(文章最后有干货)【转】

转自&#xff1a;https://blog.csdn.net/wuxianglonghaohao/article/details/21602305 http://www.newhottopic.com/2014/03/20/reverse-bits/ 把一个无符号整数的比特位反转顺序。有很多种方法来实现这个。我们这里给出一个算法&#xff1a;通过异或运算来交换&#xff0c;然后…

过关斩将打进Kaggle竞赛Top 0.3%,我是这样做的

作者 | Lavanya Shukla译者 | Monanfei责编 | 夕颜出品 | AI科技大本营&#xff08;id&#xff1a;rgznai100&#xff09;导读&#xff1a;刚开始接触数据竞赛时&#xff0c;我们可能会被一些高大上的技术吓到。各界大佬云集&#xff0c;各种技术令人眼花缭乱&#xff0c;新手们…

JavaBean规范

2019独角兽企业重金招聘Python工程师标准>>> &#xff08;1&#xff09;JavaBean 类必须是一个公共类&#xff0c;并将其访问属性设置为 public &#xff08;2&#xff09;JavaBean 类必须有一个空的构造函数&#xff1a;类中必须有一个不带参数的公用构造器&#x…

vigra1.8.0的使用

VIGRA stands for "Vision with Generic Algorithms". Its a novel computer vision library that puts its main emphasis oncustomizablealgorithms and data structures. 1、首先&#xff0c;从http://hci.iwr.uni-heidelberg.de/vigra/下载最新源代码&#xff0…

17个Python小窍门

python中相对不常见却很实用的小窍门。 空谈不如来码代码吧&#xff1a; 交换变量值 给列表元素创建新的分隔符 找列表中出现次数最多的元素 核对两个字符是否为回文 反向输出字符串 反向输出列表 转置2维数组 链式比较 我刚整理了一套2018最新的0基础入门和进阶教程&#xff0…

用产品思路建设中台,这走得通吗?| 白话中台

作者 | 王健&#xff0c;ThoughtWorks首席咨询师。 十多年国内外大型企业软件设计开发&#xff0c;团队组织转型经验。一直保持着对技术的热爱&#xff0c;热衷于技术分享。目前专注在企业平台化转型、中台战略规划&#xff0c;微服务架构与实施&#xff0c;大型遗留系统服务化…

利用cvMinAreaRect2求取轮廓最小外接矩形

转自&#xff1a;http://blog.csdn.net/mine1024/article/details/6044856 对给定的 2D 点集&#xff0c;寻找最小面积的包围矩形&#xff0c;使用函数&#xff1a; CvBox2D cvMinAreaRect2( const CvArr* points, CvMemStorage* storageNULL ); points 点序列或点集数组 …

电脑开机显示Invalidsystemdisk

开机或重启无法进入系统&#xff0c;并在屏幕上显示Invalidsystemdisk&#xff0c;Replacethediskandthenpressanykey或者diskerror之类的字样&#xff0c;这是怎么回事&#xff0c;该如何解决&#xff1f;今天u大师就为大家解决下。 出现这个原因是因为现在的电脑没有可以启…

Windows7 64位下vs2008配置OpenCV2.3.1

1、下载OpenCV2.3.1&#xff1a;http://www.opencv.org.cn/index.php/Download&#xff1b; 2、下载后解压缩&#xff1a;OpenCV-2.3.1-win-superpack.exe&#xff0c;生成一个opencv文件夹&#xff1b; 3、下载CMake&#xff1a;http://www.cmake.org/cmake/resources/softw…

腾讯拥抱开源:首次公布开源路线图,技术研发向共享、复用和开源迈进

整理 | 夕颜出品 | AI科技大本营&#xff08;ID:rgznai100&#xff09;导读&#xff1a;去年&#xff0c;知乎上一篇讨论腾讯技术的帖子异常火爆&#xff0c;讨论的主题是当下&#xff08;2018 年&#xff09;腾讯的技术建设是否处于落后同体量公司的状态&#xff0c;这篇帖子得…

Babylon.js 3.3发布:更强大的粒子系统和WebVR支持

Babylon.js 3.3版本利用微软混合现实工具包&#xff08;MRTK&#xff09;的功能来改进WebVR开发&#xff0c;并改进了其粒子系统控件。 MRTK提供了一系列脚本和组件来加速混合现实应用程序的开发。为了简化GUI VR构建&#xff0c;Bablyon.js利用3D体积网格来布局VR场景的界面&a…

基于Erlang语言的视频相似推荐系统 | 深度

作者丨gongyouliu来源 | 转载自大数据与人工智能&#xff08;ID:ai-big-data&#xff09;【导语】&#xff1a;作者在上一篇文章《基于内容的推荐算法》中介绍了基于内容的推荐算法的实现原理。在本篇文章中作者会介绍一个具体的基于内容的推荐算法的实现案例。该案例是作者在2…

MinGW简介

转自&#xff1a;http://baike.baidu.com/view/98554.htm MinGW是指只用自由软件来生成纯粹的Win32可执行文件的编译环境&#xff0c;它是Minimalist GNU on Windows的略称。这里的“纯粹”是指使用msvcrt.dll的应用程序。无法使用MFC (Microsoft Foundation Classes微软基础类…

Confluence 6 创建小组的公众空间

2019独角兽企业重金招聘Python工程师标准>>> 现在是我们可以开始创建公众空间的时候了&#xff0c;全世界都希望知道这个项目和勇敢的探险活动。 在这个步骤中&#xff0c;我们将会创建一个项目小组的空间&#xff0c;并且将这个空间公布给全世界。这个表示的是你将…

windows 7 可以清除的文件

缓解系统磁盘空间不足的情况1、系统盘根目录下的MSOCache是office的安装备份文件&#xff0c;可以删除。2、c:\user\用户名\appdate\local\temp是软件安装时留下的临时文件。3、c:\windows\SoftwareDistribution中存放的是系统补丁更新包及旧的系统文件。4、c:\windows\winsxs\…

阿里最新论文解读:考虑时空域影响的点击率预估模型DSTN

作者 | 石晓文转载自小小挖掘机&#xff08;ID: wAIsjwj&#xff09;【导语】&#xff1a;在本文中&#xff0c;阿里的算法人员同时考虑空间域信息和时间域信息&#xff0c;来进行广告的点击率预估。什么是时空域&#xff1f;我们可以分解为空间域(spatial domain)和时间域(tem…

windows7 64位机上配置MinGW+Codeblocks+ wxWidgets

在Windows7 64位机子上安装配置MinGWCodeblockswxWidgets步骤如下&#xff1a; 1、 下载mingw-get-inst-20111118&#xff1a;http://sourceforge.net/projects/mingw/&#xff1b; 2、 双击mingw-get-inst-20111118.exe&#xff0c;一般按默认即可&#xff0c;选择自己需要…

jQuery带动画的弹出对话框

在线演示 本地下载

陶哲轩实分析 习题 13.4.6

设 $(X,d)$ 是度量空间,并设 $(E_{\alpha})_{\alpha\in I}$ 是 $X$ 中的一族连通集合.还设 $\bigcap_{\alpha\in I}E_{\alpha}$ 不空.证明 $\bigcup_{\alpha\in I}E_{\alpha}$ 是连通的.证明:由于 $\bigcap_{\alpha\in I}E_{\alpha}$ 是不空的,因此存在 $p\in \bigcap_{\alpha\…

一年参加一次就够,全新升级的AI开发者大会议程出炉!

“只讲技术&#xff0c;拒绝空谈”的AI开发者大会再次来临&#xff01;2018 年的AI开发者大会&#xff0c;作为年度人工智能领域面向专业开发者的一次高规格技术盛会&#xff0c;上千名开发者与上百名技术专家齐聚一堂&#xff0c;大会以“AI技术与应用”为核心&#xff0c;就人…

Windows7下配置MinGW+CodeBlocks+OpenCV2.3.1

1、下载mingw-get-inst-20111118&#xff1a;http://sourceforge.net/projects/mingw/&#xff1b; 2、双击mingw-get-inst-20111118.exe&#xff0c;一般按默认即可&#xff0c;选择自己需要的组件&#xff1b; 3、添加MinGW环境变量&#xff1a;选择计算机-->点击右键--…

Spark SQL基本操作以及函数的使用

2019独角兽企业重金招聘Python工程师标准>>> 引语&#xff1a; 本篇博客主要介绍了Spark SQL中的filter过滤数据、去重、集合等基本操作&#xff0c;以及一些常用日期函数&#xff0c;随机函数&#xff0c;字符串操作等函数的使用&#xff0c;并列编写了示例代码&am…

OpenCV提取轮廓(去掉面积小的轮廓)

转自&#xff1a;http://www.kaixuela.net/?p23 #include <stdio.h> #include "cv.h" #include "cxcore.h" #include "highgui.h" #include <iostream> using namespace std; #pragma comment(lib,"cv.lib") #pra…

软工作业 5:词频统计——增强功能

一、基本信息 1.1 编译环境、项目名称、作者 1 #编译环境:python3.6 2 #项目名称&#xff1a;软工作业5-词频统计—增强功能 3 #作者&#xff1a;1613072055 潘博 4 # 1613072056 侯磊 1.2项目地址 本次作业地址: https://www.cnblogs.com/panboo/项目git地址: https://g…

Linux之文件权限管理

chmod ux转载于:https://www.cnblogs.com/chaoren399/archive/2013/03/11/2953727.html

如果三十年前有这些AI技术,可可西里的悲剧不会发生

作者 | 神经小姐姐来源 | HyperAI超神经&#xff08;ID&#xff1a;HyperAI&#xff09;而被盗猎者大量的非法捕杀。多种野生动物都处于濒临灭绝的局面&#xff0c;人工智能等技术&#xff0c;能够在帮助保护野生动物上&#xff0c;发挥比较大的作用&#xff0c;让我们能够生存…

Percona-Server-5.5.30安装

1、安装系统环境 yum install -y gcc gcc-c autoconf automake zlib* libxml* ncurses-devel libmcrypt* libtool-ltdl-devel* cmake bison 2、下载源码包 1 http://www.percona.com/downloads/ 2 3 wget -c http://www.percona.com/redir/downloads/Percona-Server-5.5/Perc…

OpenCV中SVM的使用

转自&#xff1a;http://download.csdn.net/download/gaogaogao124/3125857 略有改动&#xff1a; #include"stdafx.h" #include<opencv2/opencv.hpp> #include<cmath> #include<ctime> using namespace std; int _tmain(int argc,_TCHAR…

数据不够,用GAN来凑!

作者 | CV君来源 | 我爱计算机视觉&#xff08;ID&#xff1a;aicvml&#xff09;在计算机视觉领域&#xff0c;深度学习方法已全方位在各个方向获得突破&#xff0c;这从近几年CVPR 的论文即可看出。但这往往需要大量的标注数据&#xff0c;比如最著明的ImageNet数据集&#x…