Why:為什么需要SPI?
我們系統(tǒng)里抽象的各個模塊,往往有很多不同的實現(xiàn)方案,比如日志模塊的方案,xml解析模塊、jdbc模塊的方案等。面向的對象的設計里,我們一般推薦模塊之間基于接口編程,模塊之間不對實現(xiàn)類進行硬編碼。一旦代碼里涉及具體的實現(xiàn)類,就違反了可拔插的原則,如果需要替換一種實現(xiàn),就需要修改代碼。為了實現(xiàn)在模塊裝配的時候能不在程序里動態(tài)指明(在類路徑下去找...),這就需要一種服務發(fā)現(xiàn)機制。java spi就是提供這樣的一個機制:為某個接口尋找服務實現(xiàn)的機制。有點類似IOC的思想,就是將裝配的控制權移到程序之外,在模塊化設計中這個機制尤其重要。
How:怎么實現(xiàn)SPI?
第一步,建立日志服務接口jar
1.1 工程結構

1.2 Logger接口

1.3 LoggerFactory類

1.4 工程打成jar包?

第二步,建立日志服務的具體實現(xiàn)
2.1 工程結構

說明:(1)引入my-logging.jar;(2)新建一個Log5j類實現(xiàn)Logger接口;(3)新建一個META-INF/services文件夾,建一個你要實現(xiàn)的接口的名字命名的文件,既是com.my.Logger,里面的內容就是這個接口的實現(xiàn)類的完全限定名,既是com.log5j.Log5j。
2.2?Logger接口實現(xiàn)類Log5j

2.3 配置文件com.my.Logger

2.4 打包

第三步,建立測試項目test
3.1 工程結構

3.2 測試類Test

3.3 測試結果

What:什么是SPI?
SPI的全名為Service Provider Interface.大多數(shù)開發(fā)人員可能不熟悉,因為這個是針對廠商或者插件的。在java.util.ServiceLoader的文檔里有比較詳細的介紹。java spi的具體約定為:當服務的提供者,提供了服務接口的一種實現(xiàn)之后,在jar包的META-INF/services/目錄里同時創(chuàng)建一個以服務接口命名的文件。該文件里就是實現(xiàn)該服務接口的具體實現(xiàn)類。而當外部程序裝配這個模塊的時候,就能通過該jar包META-INF/services/里的配置文件找到具體的實現(xiàn)類名,并裝載實例化,完成模塊的注入。?基于這樣一個約定就能很好的找到服務接口的實現(xiàn)類,而不需要再代碼里制定。jdk提供服務實現(xiàn)查找的一個工具類:java.util.ServiceLoader.