金庆的专栏

  C++博客 :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理 ::
  423 随笔 :: 0 文章 :: 454 评论 :: 0 Trackbacks
log4cxx调试日志选择性输出的配置方法

(转载请注明来源于金庆的专栏)

一般是每个类都有自己的日志, 可建立一个静态成员logger如下:

class A
{
private:
    static log4cxx::LoggerPtr logger;
};

需要在cpp文件中静态初始化:

log4cxx::LoggerPtr A::logger = log4cxx::Logger::getLogger("A");

日志类别名"A"就是类名, 也可以是模块名.类名, 如"DB.A".

log4cxx的惯例是使用这样一个静态成员.
但也可以是静态成员logger(), 这样不必静态初始化.

class A
{
private:
    static log4cxx::LoggerPtr logger()
    {
        return log4cxx::Logger::getLogger("A");
    }
};

但从效率考虑, 每次调用日志都要getLogger()不如静态初始化.

类代码中调用日志只需:

    LOG4CXX_DEBUG(logger, "test log...");

日志配置log4j.properties如下:

log4j.rootLogger=WARN, R

log4j.appender.R=org.apache.log4j.RollingFileAppender
log4j.appender.R.File=log.txt
log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=%d %5p %c %x: %m%n

# log4j.logger.DB.A=DEBUG

默认所有日志等级为WARN, 不会输出DEBUG日志,
只需显式设定某一类日志的级别, 就可以选择性地输出该类日志.
如调试A类时, 取消配置文件中的注释就行了.



posted on 2009-02-16 14:48 金庆 阅读(4037) 评论(4)  编辑 收藏 引用 所属分类: 1. C/C++

评论

# re: log4cxx调试日志选择性输出的配置方法 2009-02-17 09:15 士大夫
[url=http://www.dahua-tech.cn/pclass05.html]压滤机配件[/url]   回复  更多评论
  

# re: log4cxx调试日志选择性输出的配置方法 2009-02-17 09:18 士大夫
<a href="http://www.hzjpxs.cn">杭州机票</a>  回复  更多评论
  

# re: log4cxx调试日志选择性输出的配置方法 2009-02-19 19:09 许海斌
呵呵,和我的做法差不多

类中的静态成员变量声明:
static log4cxx::LoggerPtr logger;

cpp文件中的定义:
LoggerPtr connection::logger = Logger::getLogger(constants::Connection);

  回复  更多评论
  

# re: log4cxx调试日志选择性输出的配置方法 2009-05-07 15:46 tangxinfa
简单优先,至于性能,呵呵,要量过才知道。

#include "log4cxx/logger.h"
#define LOGGER(name) log4cxx::Logger::getLogger(name)

LOG4CXX_ERROR(LOGGER("Mgr"), "内部错误,可能是人品有问题");  回复  更多评论
  


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理