log4cpp第一个程序HelloWord

body, table{font-family: 微软雅黑; font-size: 10pt} table{border-collapse: collapse; border: solid gray; border-width: 2px 0 2px 0;} th{border: 1px solid gray; padding: 4px; background-color: #DDD;} td{border: 1px solid gray; padding: 4px;} tr:nth-child(2n){background-color: #f8f8f8;}

让我们从一个简单的例子开始,该例子将两条日志信息写入字符串流,该流会在标准控制台cout上输出,项目的名称是HelloLog4Cpp:

//步凑:

//1. 创建一个Appender,并指定其包含的Layout;

//2. 从系统中得到Category的根,将Appender添加到该Category中;

//3. 设置Category的优先级;

//4. 记录日志;

//5. 关闭Category。


#include <iostream>

#include <log4cpp/Category.hh>               //负责向日志中写入信息

#include <log4cpp/OstreamAppender.hh>        //负责指定日志的目的地

#include <log4cpp/BasicLayout.hh>            //负责设定日志的格式

#include <log4cpp/Priority.hh>               //指定Category的优先级和日志的优先级

using namespace std;

using namespace log4cpp;

int main(void)

{

//指定日志输出目的地

OstreamAppender * pOstremAppender =

new OstreamAppender("osAppender", &cout);

//设置格式化日志信息

pOstremAppender->setLayout(new BasicLayout());

//负责输出日志

Category & root = Category::getRoot();

root.addAppender(pOstremAppender);

root.setPriority(Priority::ERROR);

//写日志

root.error("hello log4cpp in a Error Message!");

root.warn("hello log4cpp in a warn Message!");

//关闭Category

Category::shutdown();

return 0;

}


//系统中可以有多个Category,它们都继承自同一个跟root,每个Category负责记录自己的日志;

//每个Category可以添加多个Appender(目的地,日志要输出到哪),每个Appender制定了一个日志的目的地;

//这个目的地可以是文件,字符流或者windws日志,当Category记录一条日志时,该日志被写入所有

//附加到此Category的Appender;

//每个Append都包含一个Layout,该Layout定义了这个Appender上日志的格式。

//

#include<iostream>

#include<log4cpp/Category.hh>

#include<log4cpp/OstreamAppender.hh>

#include<log4cpp/BasicLayout.hh>

#include<log4cpp/Priority.hh>

using namespace std;

//引入命名空间log4cpp就可以不用加作用名限定log4cpp::

int main(int argc,char *argv[])

{

  //指定日志输出目的地;附加目的地,cout,输出终端;堆对象,防止超出作用域被释放

log4cpp::OstreamAppender* osAppender = new log4cpp::OstreamAppender("osAppender",&cout);

//设置格式化日志信息;设置APPender的布局

osAppender->setLayout(new log4cpp::BasicLayout());

//负责输出日志;得到系统的根root

log4cpp::Category& root = log4cpp::Category::getRoot();

//把设置好的Append添加到系统root下

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;

}

//1514104975 ERROR  : Hello log4cpp in a Error Message!

//1514104975 WARN  : Hello log4cpp in a Warning Message!


编译:g++ helloworld.cpp -o helloworld -llog4cpp -lpthread

运行结果:1248337987 ERROR : Hello log4cpp in a Error Message!

1248337

注:以上两条日志格式很简陋,要设置合乎心意的日志格式,请参考后续的PatternLayout章节。

相关概念:

  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的顺序来依次介绍这些概念并给出例子。

原文地址:https://www.cnblogs.com/meihao1203/p/8872033.html

时间: 2024-10-08 07:59:03

log4cpp第一个程序HelloWord的相关文章

hibernate的第一应用程序

1.hibernate是站在JDBC的基础上的框架,远比JDBC好用,它的的开发步骤如下: (1)在工程下建一个lib包,导入用到的jar包 (2).写一个pojo类 (3).配置pojo类名.hbm.xml文件 (4).配置hibernate.cfg.xml文件 (5)写应用程序类 2.代码实战: (1).导入如下的jar包,本人用数据库是MySQL 2.写一个POJO类 package cn.wwh.www.hibernate.aa.helloword; /** *类的作用: * * *@a

java学习 之 第一个程序及认识

以前也看过一系列的java方面的程序,但是还没有正式敲过,今天正式学习并且正式敲出代码.在这里记录下来今日所得 写作工具:Notepad++ 在写作工具方面好多人建议用 记事本,但是我还是认为用 Notepad++ 这个编辑工具比较好. 这个相较于记事本来说,关键字可以编写,能够提高学习中的拼写错误提交效果: 再者,写好以后也要手动执行命令,更能够知道程序是怎么运行的. 第一个程序 public class HelloWorld { public static void main(String

Python 学习笔记(六)Python第一个程序

Python 语句 赋值语句 1.将3对象赋值给了变量a 2.将3,4赋值给了变量a,b 1 >>> a = 3 2 >>> a ,b = 3,4 3 >>> a 4 3 5 >>> b 6 4 7 >>> a = 3,4 8 >>> a 9 (3, 4) 3.实现将a,b=3,4进行调换a,b=4,3 1 >>> a,b =3,4 一般我们声明一个临时变量来解决 2 >&g

java基础--JDK安装、环境变量配置、工具开发第一个程序、数据类型、运算符

**-----Java基础大纲-----**   **-----本章节-----** 1.Java语言的历史.特点及工作原理 2.JRE和JDK的介绍 3.Java运行环境和开发工具 4.Java基础语法 **-----下一章节-----** 5.条件语句 6.循环 7.数组 ============================================== 一:历史及开发准备 1.Java发展历程及来源 (1)发展历程 1996年1月,Sun公司发布了Java的第一个开发工具包(JD

Linux下C++的编程——开发环境搭建与第一个程序

上一篇文章Linux下C++的编程--开偏介绍中我们已经介绍了GUN.GCC.G++等一些重要的概念,现在应该开始动手实践了! 开发工具的安装 环境 Distributions版本:CentOS 6.7 Linux内核片:2.6.32-573.3.1.el6.i686 一般Linux安装完之后默认就已经安装了GCC(GNU Compiler Collection),你可以查看一下gcc和g++的版本号检查gcc和g++是否已经安装. [luowf@luoweifu ~]$ gcc -v gcc

日更第2期-2015-1-15-openFrameworks系列第一讲-手把手制作openFrameworks上的第一个程序!

恩,今天和朋友打球来着,于是今天的案例程序就做一个球吧!O(∩_∩)O哈哈~ 首先,没有看过上一篇教程的同学,还有还没有下载好VS和OpenFrameworks的同学,都去下一下. 传送地址:http://www.cnblogs.com/linongbo/p/4227552.html 那么,开始今天的日更啦! Hello OpenFrameworks! VS的安装部分我就不说了,不过我个人建议——默认是安装在C盘的,不过你要是手动改到别的盘上的话,C盘上 依然会有6G左右的内容.......Σ(

[Fluent NHibernate]第一个程序

目录 写在前面 Fluent Nhibernate简介 基本配置 总结 写在前面 在耗时两月,NHibernate系列出炉这篇文章中,很多园友说了Fluent Nhibernate的东东,也激起我的兴趣,想对它一探究竟,这里也将Fluent Nhibernate写成一个系列,记录自己的学习过程,关于这东东,也是第一次接触,也只能边摸索,边记录了.如果有描述错误的地方,还望多多包涵. 通过Nhibernate的学习,都觉得Nhibernate的使用映射文件的编写很麻烦,这里通过Fluent Nhi

Android使用AndEngine创建第一个程序

首先要把andengine.jar复制到libs文件夹里 01 package com.hu.anden; 02   03 import org.anddev.andengine.engine.Engine; 04 import org.anddev.andengine.engine.camera.Camera; 05 import org.anddev.andengine.engine.options.EngineOptions; 06 import org.anddev.andengine.

在Win7(64位)使用VS2015运行《OpenGL编程指南》第八版第一章程序的方法

前言:笔者第一次用vs2015来实现<OpenGL编程指南>第八版第一个程序时确实花费了不少时间,按照网上教程,尝试了各种方法,最终花费了两个上午加一个下午的时间, 成功运行了程序,花了这么多时间,确实让人懊恼,现在把运行程序的步骤记录下来,以便查阅. 1.第一步,下载oglpg-8th-edith. 如果去书本上的官网下载,下载的是第九版的,而不是第八版的源码. 去其他网站下载,下载的这个包里面没有第一章的源码,可以网上黏贴其他人的代码,建议下第八版源码,下载网址:链接:http://pan