发布于 2016-10-30 09:36:16 | 328 次阅读 | 评论: 0 | 来源: PHPERZ

很多时候我们为了在类中加日志不得不写一行,而且还要去手动改XXX这个类名

private static Logger log = LoggerFactory.getLogger(XXX.class);

第二个问题,我特别喜欢这种形式:

log.info("我在XXX 改了 {} 变量", "name");
既省去了可恶的isInfoEnabled()的判断,还避免了拼接字符串,但是呀
log.error("错误消息", e);

这样就不支持了,烦躁……

写多了就觉得这种厌烦的工作实在让人无法忍受,于是就封装了下。

Demo:

import com.xiaoleilu.hutool.log.Log;
import com.xiaoleilu.hutool.log.LogFactory;
import com.xiaoleilu.hutool.log.dialect.ApacheCommonsLogFactory;
import com.xiaoleilu.hutool.log.dialect.ConsoleLogFactory;
import com.xiaoleilu.hutool.log.dialect.JdkLogFactory;
import com.xiaoleilu.hutool.log.level.Level;

public class LogDemo {
    public static void main(String[] args) {
        Log log = LogFactory.get();

        System.out.println("----------------------------自动选择日志------------------------------");
        // 自动选择日志实现
        log.debug("This is {} log", Level.DEBUG);
        log.info("This is {} log", Level.INFO);
        log.warn("This is {} log", Level.WARN);
        log.error("This is {} log", Level.ERROR);

        System.out.println("----------------------------自定义为Common Log日志------------------------------");
        // 自定义日志实现
        LogFactory.setCurrentLogFactory(new ApacheCommonsLogFactory());
        log = LogFactory.get();
        log.debug("This is {} log", Level.DEBUG);
        log.info("This is {} log", Level.INFO);
        log.warn("This is {} log", Level.WARN);
        log.error("This is {} log", Level.ERROR);

        System.out.println("----------------------------自定义为JDK Log日志------------------------------");
        // 自定义日志实现
        LogFactory.setCurrentLogFactory(new JdkLogFactory());
        log = LogFactory.get();
        log.debug("This is {} log", Level.DEBUG);
        log.info("This is {} log", Level.INFO);
        log.warn("This is {} log", Level.WARN);
        log.error("This is {} log", Level.ERROR);

        System.out.println("----------------------------自定义为Console Log日志------------------------------");
        // 自定义日志实现
        LogFactory.setCurrentLogFactory(new ConsoleLogFactory());
        log = LogFactory.get();
        log.debug("This is {} log", Level.DEBUG);
        log.info("This is {} log", Level.INFO);
        log.warn("This is {} log", Level.WARN);
        log.error("This is {} log", Level.ERROR);
    }
}

总结下来如果日志比较少,可以直接使用静态方法StaticLog.xxx,如果日志量很大,那么首先要构建好Logger,使用:

private static final Log log = LogFactotry.get();

log.debug("This is {} log", Level.DEBUG);
log.info("This is {} log", Level.INFO);
log.warn("This is {} log", Level.WARN);
log.error("This is {} log", Level.ERROR);

比之前简短了很多,而且随便复制。 调用log.xxx(log, "消息");

对于不能使用format的情况,我把Throwable放在前面了,这样就可以使用动态参数了 Object... argument

好吧,就到这里,欢迎批评指正以及提供意见~~~

最新网友评论  共有(0)条评论 发布评论 返回顶部

Copyright © 2007-2017 PHPERZ.COM All Rights Reserved   冀ICP备14009818号  版权声明  广告服务