国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發(fā)設(shè)計 > 正文

slf4j-api、slf4j-log4j12以及l(fā)og4j之間什么關(guān)系?

2019-11-14 10:40:49
字體:
供稿:網(wǎng)友

來源:http://blog.csdn.net/tengdazhang770960436/article/details/18006127

幾乎在每個jar包里都可以看到log4j的身影,在多個子工程構(gòu)成項目中,slf4j相關(guān)的沖突時不時就跳出來讓你不爽,那么slf4j-api、slf4j-log4j12還有l(wèi)og4j他們是什么關(guān)系?我把自己了解的和大家簡單分享一下:

    slf4j:Simple Logging Facade for java,為java提供的簡單日志Facade。Facade:門面,更底層一點說就是接口。他允許用戶以自己的喜好,在工程中通過slf4j接入不同的日志系統(tǒng)。更直觀一點,slf4j是個數(shù)據(jù)線,一端嵌入程序,另一端鏈接日志系統(tǒng),從而實現(xiàn)將程序中的信息導(dǎo)入到日志系統(tǒng)并記錄。 

   因此,slf4j入口就是眾多接口的集合,他不負責具體的日志實現(xiàn),只在編譯時負責尋找合適的日志系統(tǒng)進行綁定。具體有哪些接口,全部都定義在slf4j-api中。查看slf4j-api源碼就可以發(fā)現(xiàn),里面除了public final class LoggerFactory類之外,都是接口定義。因此,slf4j-api本質(zhì)就是一個接口定義。

      

下圖比較清晰的描述了他們之間的關(guān)系:

   

     

  當系統(tǒng)采用log4j作為日志框架實現(xiàn)的調(diào)用關(guān)系:

    

    首先系統(tǒng)包含slf4j-api作為日志接入的接口;

    

    at compile時slf4j-api中public final class LoggerFactor類中

    PRivate final static void bind() 方法會尋找具體的日志實現(xiàn)類綁定,主要通過    StaticLoggerBinder.getSingleton();語句調(diào)用

    

  

   slf4j-log4j12:鏈接slf4j-api和log4j中間的適配器。它實現(xiàn)了slf4j-apiz中StaticLoggerBinder接口,從而使得在編譯時綁定的是slf4j-log4j12的getSingleton()方法

log4j:這個是具體的日志系統(tǒng)。通過slf4j-log4j12初始化Log4j,達到最終日志的輸出。


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 禄丰县| 宜阳县| 五河县| 菏泽市| 阿尔山市| 尖扎县| 兴隆县| 辽宁省| 永昌县| 沛县| 云梦县| 油尖旺区| 顺昌县| 兰考县| 肇州县| 河间市| 甘南县| 南和县| 曲周县| 盐城市| 噶尔县| 金溪县| 长顺县| 兴山县| 三江| 额尔古纳市| 漳平市| 噶尔县| 潼关县| 安平县| 华宁县| 清苑县| 曲周县| 井研县| 泰顺县| 马尔康县| 广宁县| 独山县| 海南省| 金昌市| 株洲市|