slf4j-api只实现了日志接口,它的具体实现是slf4j-log4j12和slf4j-jdk14。
slf4j-log4j12是使用的log4j管理日志。slf4j-jdk14使用jdk14管理日志。
在组件实现的时候只需要引用slf4j-api的接口记录日志,而由主程序选择使用哪种方式管理日志,实现了日志的灵活配置。
配置:
slf4j-api+slf4j-log4j12
slf4j-api+slf4j-jdk14
那么这种灵活配置实现的原理是怎样的?slf4j-api是怎样知道调用不同的日志实现方式?
通过查看源码slf4j-api中调用StaticLoggerBinder来获取实现类工厂对象,这个类并不在slf4j-api中,是在slf4j-log4j12和slf4j-jdk14中实现。
slf4j-api和实现组件约定好,实现类一定要实现名称为StaticLoggerBinder的工厂类,然后由slf4j-api来调用,实现灵活配置。
这种实现方式很简单,但是在真实写代码的时候却不是十分容易想到。