log4cxx调试日志选择性输出的配置方法

 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类时, 取消配置文件中的注释就行了.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值