说起日志系统,不得不提大名鼎鼎的Log4j。特别是使用Java的人们,能够说是无人不知无人不晓无人不用。

Log4j以其简单的使用方式(引入一个jar包。一行代码就可以调用)。灵活(可通过配置文件任意配置),功能强大(多个级别。可配置多个输出目的地,Console,File。系统日志。远端的LogServer等等,可订制日志格式,自己主动产生,删除日志文件)等等等等特性,一直是Java日志系统的首选。

1.Log4j的C++版本号Log4cplus

上面说到,日志在如今的系统里不可缺少。Java有功能强大的Log4j能够使用,作为最重要变成语言之中的一个的C++有什么选择呢?

幸运的是。有一些大牛非常早之前就发现了这个问题,他们仿照Log4J。使用C++语言开发了一套日志系统Log4cplus,Log4cplus的目的非常明白。打造C++版的Log4j。并且最重要的是Log4cplus是开源的。

2.使用简单介绍

1)下载http://sourceforge.net/projects/log4cplus/

2)Log4j是一个C++库,编译以后就可以使用。同一时候log4cplus支持windows和linux:

windows下:打开根文件夹下的msvc10以下的vsproject。编译就可以。

Linux下:configure, make

3)使用

a)最简单的使用方式

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#include
<log4cplus/logger.h> 
#include
<log4cplus/configurator.h> 
#include
<iomanip> 
   
using

namespace

log4cplus; 
   
int 
main() 
    BasicConfigurator
config; 
    config.configure(); 
   
    Logger
logger = Logger::getInstance(
"main"); 
    LOG4CPLUS_WARN(logger, "Hello,
World!"
); 
    return

}

b)可订制的方式

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
/*   
严格实现步骤1-6,appender输出到屏幕, 当中的布局格式和LogLevel后面会详解。*/
 
#include
<log4cplus logger.h=""></log4cplus> 
#include
<log4cplus consoleappender.h=""></log4cplus> 
#include
<log4cplus layout.h=""></log4cplus>    
using

namespace

log4cplus; 
using

namespace

log4cplus::helpers;    
int

main(){ 
    /*
step 1: Instantiate an appender object */
     
    SharedObjectPtr
_append (
new

ConsoleAppender());     
    _append->setName("append
for test"
);    
    /*
step 2: Instantiate a layout object */
     
    std::string
pattern = 
"%d{%m/%d/%y
%H:%M:%S}  - %m [%l]%n"
;     
    std::auto_ptr
_layout(
new

PatternLayout(pattern));    
    /*
step 3: Attach the layout object to the appender */
     
    _append->setLayout(
_layout );    
    /*
step 4: Instantiate a logger object */
     
    Logger
_logger = Logger::getInstance(
"test");    
    /*
step 5: Attach the appender object to the logger  */
    
    _logger.addAppender(_append);    
    /*
step 6: Set a priority for the logger  */
     
    _logger.setLogLevel(ALL_LOG_LEVEL);    
     /*
log activity */
     
    LOG4CPLUS_DEBUG(_logger, "This
is the FIRST log message..."
)     
   sleep(1);     
   LOG4CPLUS_WARN(_logger, "This
is the SECOND log message..."
)    
   return

0; 
}

4)配置

Log4cplus配置基本与log4J同样。

以下是一个样例

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
log4cplus.rootLogger=DEBUG,
STDOUT, ALL_MSGS 
   
   
log4cplus.appender.STDOUT=log4cplus::ConsoleAppender 
log4cplus.appender.STDOUT.layout=log4cplus::PatternLayout 
#log4cplus.appender.STDOUT.layout.ConversionPattern=%d{%m/%d/%y
%H:%M:%S} [%t] %-5p %c{2} %%%x%% - %m [%l]%n 
log4cplus.appender.STDOUT.layout.ConversionPattern=[%-5p
%d{%y-%m-%d %H:%M:%S}] [%l]%n%m%n%n 
   
   
#设置日志追加到文件尾 
log4cplus.appender.ALL_MSGS=log4cplus::RollingFileAppender   
   
#设置日志文件大小 
log4cplus.appender.ALL_MSGS.MaxFileSize=100MB 
   
#设置生成日志最大个数 
log4cplus.appender.ALL_MSGS.MaxBackupIndex=10 
   
#设置输出日志路径 
log4cplus.appender.ALL_MSGS.File=log/test.log 
log4cplus.appender.ALL_MSGS.layout=log4cplus::PatternLayout 
#设置日志打印格式 
#log4cplus.appender.ALL_MSGS.layout.ConversionPattern=|%D:%d{%Q}|%p|%t|%l|%m|%n 
log4cplus.appender.ALL_MSGS.layout.ConversionPattern=[%-5p
%d{%y-%m-%d %H:%M:%S}] [%l]%n%m%n%n 
#匹配同样日志级别,仅仅有debug日志才输入到该文件里 
#log4cplus.appender.ALL_MSGS.filters.1=log4cplus::spi::LogLevelMatchFilter 
#log4cplus.appender.DEBUG_MSGS.filters.1.LogLevelToMatch=DEBUG 
#log4cplus.appender.DEBUG_MSGS.filters.1.AcceptOnMatch=true 
#log4cplus.appender.DEBUG_MSGS.filters.2=log4cplus::spi::DenyAllFilter

log4cplus基本用法的更多相关文章

  1. 转载的log4cplus使用指南

    以下转载的log4cplus使用指南的版本可能不是最新,仅作参考了解.应以最新安装包中的示例代码为准. 目    录1 Log4cplus简介    52 安装方法    53 主要类说明    64 ...

  2. Log4cplus使用指南

    1.  Log4cplus简介 log4cplus是C++编写的开源的日志系统,前身是java编写的log4j系统,受Apache Software License保护,作者是Tad E. Smith ...

  3. How to use Log4cplus

    Introduction Log4cplus is derived by the popular Log4j written in java.<br>This tutorial show ...

  4. Log4cplus入门

    Log4cplus使用指南 1.  Log4cplus简单介绍 log4cplus是C++编写的开源的日志系统,前身是java编写的log4j系统.受Apache Software License保护 ...

  5. EditText 基本用法

    title: EditText 基本用法 tags: EditText,编辑框,输入框 --- EditText介绍: EditText 在开发中也是经常用到的控件,也是一个比较必要的组件,可以说它是 ...

  6. jquery插件的用法之cookie 插件

    一.使用cookie 插件 插件官方网站下载地址:http://plugins.jquery.com/cookie/ cookie 插件的用法比较简单,直接粘贴下面代码示例: //生成一个cookie ...

  7. Java中的Socket的用法

                                   Java中的Socket的用法 Java中的Socket分为普通的Socket和NioSocket. 普通Socket的用法 Java中的 ...

  8. [转载]C#中MessageBox.Show用法以及VB.NET中MsgBox用法

    一.C#中MessageBox.Show用法 MessageBox.Show (String) 显示具有指定文本的消息框. 由 .NET Compact Framework 支持. MessageBo ...

  9. python enumerate 用法

    A new built-in function, enumerate() , will make certain loops a bit clearer. enumerate(thing) , whe ...

随机推荐

  1. html 中几次方,平方米,立方米.

    m的n次方表示法:mn m<sup>n</sup> 10<sup>6</sup> m的n次方表示法:mn m<sub>n</sub&g ...

  2. 一些Java面试题深入分析

    一.&和&&的差别? &和&&都能够用作逻辑与的运算符.表示逻辑与(and),当运算符两边的表达式的结果都为true时.整个运算结果才为true,否则, ...

  3. [Done]java.sql.SQLException: Connection is read-only. Queries leading to data modification are not allowed

    java.sql.SQLException: Connection is read-only. Queries leading to data modification are not allowed ...

  4. jenkins+gitlab钩子+shell脚本基于git的tag实现App增量更新

    转自:http://blog.csdn.net/kingboyworld/article/details/54175330 环境安装 jdk1.8 1.安装jenkins 首先到https://jen ...

  5. JDBC 利用反射技术将查询结果封装为对象(简单ORM实现)

    ORM(Object Relational Mapping)对象关系映射 public class ORMTest { public static void main(String[] args) t ...

  6. Servlet/Jsp实现购物车

    (1)用servlet实现简单的购物车系统,项目结构例如以下:(新建web Project项目  仅仅须要AddItemServlet , ListItemServlet.exam403.jsp三个文 ...

  7. 【TP5.0】引入public/static目录下的静态资源

    1.假设tp5 下只有一个项目,且application在tp5下, 2.我们知道 外界访问tp5项目,只能通过public/index.php的入口文件,且查看apache服务器我们知道, [DOC ...

  8. idea 编辑时cup飙升解决方案,亲测有效

    idea(64).exe.vmoptions内容如下: -Xms1024m -Xmx2048m -XX:MaxPermSize=512m -XX:ReservedCodeCacheSize=256m ...

  9. 函数适配器bind2nd 、mem_fun_ref 源码分析、函数适配器应用举例

    一.适配器 三种类型的适配器: 容器适配器:用来扩展7种基本容器,利用基本容器扩展形成了栈.队列和优先级队列 迭代器适配器:(反向迭代器.插入迭代器.IO流迭代器) 函数适配器:函数适配器能够将仿函数 ...

  10. C++的引用与const指针的关系以及各种传递方式

    首先我们知道 const int *p 与 int const *p 是一样的,即 *p 是常量:而 int * const p 跟上面是不一样的,即 p 是常量:我们知道引用只是一个别名,与变量共享 ...