资讯专栏INFORMATION COLUMN

日志框架浅析(二)

tuomao / 947人阅读

摘要:简介依赖包解析并没有实现相应的接口所以加了一层桥接层包里面的内容来实现对的调用里面的代码很简单只有个类关键的两个类是和对应的方法源码实现了的接口调用方法获取实现了的接口并且实际代理了类所以对的所有方法调用最终调用的都是对应的方法小

SLF4J&&Log4j 简介

依赖jar包:slf4j-api-x.x.x.jar,log4j.jar,slf4j-log4j12.jar

解析

log4j并没有实现slf4j相应的接口,所以加了一层桥接层(slf4j-log4j12.jar包里面的内容)来实现slf4jlog4j的调用
slf4j-log4j12.jar里面的代码很简单

只有5个类,关键的两个类是Log4jLoggerFactoryLog4jLoggerAdapter,对应Log4jLoggerFactorygetLogger方法源码:

    public Logger getLogger(String name) {
        Logger slf4jLogger = loggerMap.get(name);
        if (slf4jLogger != null) {
            return slf4jLogger;
        } else {
            org.apache.log4j.Logger log4jLogger;
            if(name.equalsIgnoreCase(Logger.ROOT_LOGGER_NAME))
                log4jLogger = LogManager.getRootLogger();
            else
                log4jLogger = LogManager.getLogger(name);
            Logger newInstance = new Log4jLoggerAdapter(log4jLogger);
            Logger oldInstance = loggerMap.putIfAbsent(name, newInstance);
            return oldInstance == null ? newInstance : oldInstance;
       }
    }

Log4jLoggerFactory实现了slf4jILoggerFactory接口,调用getLogger方法获取Logger

Log4jLoggerAdapter实现了slf4jLogger接口,并且实际代理了org.apache.log4j.Logger类,所以对Log4jLoggerAdapter的所有方法调用,最终调用的都是org.apache.log4j.Logger对应的方法

小结

log4j是通过slf4j-log4j12.jar桥接包来完美适配slf4j使用

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/67017.html

相关文章

  • 日志框架浅析(一)

    摘要:简介常用的日志主流框架基本上是基于搭配来实现日志输出依赖包解析我们获取日志实体代码具体获取日志实体源码这里类就必须在中声明并且通过调用获取一个实现了的实例这里获取单例是通过饿汉式依赖实体改成依赖一个接口是否更加优雅然后通过的 SLF4J&&Logback 简介 常用的日志主流框架基本上是基于slf4j搭配logback来实现日志输出 依赖jar包:slf4j-api-x.x.x.ja...

    fsmStudy 评论0 收藏0
  • python的logging 模块浅析

    摘要:的继承关系使用做日志输出时,首先我们需要一个创建一个对象。再设计多级别的日志系统时,尤其要注意这点。当然,这样做其实是有悖于的本意的。是什么是一个程序内全局唯一的,所有对象的祖先。因此,直接修改是危险的。 0x00 python logging的继承关系 使用python做日志输出时,首先我们需要一个创建一个Logger对象:import logging; logger = log...

    cooxer 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<