日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長(zhǎng)提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請(qǐng)做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會(huì)員:747

今天我們聊聊SPI機(jī)制,先從JDK的ServiceLoader 類談起。

一、 ServiceLoader 介紹

ServiceLoader 類是 JAVA Development Kit (JDK) 的一部分,用于加載服務(wù)提供者。這個(gè)類是 Java 的服務(wù)提供者加載機(jī)制(SPI,Service Provider Interface)的核心部分,允許服務(wù)提供者被動(dòng)態(tài)地加載到應(yīng)用程序中。這里的 "服務(wù)" 是指一個(gè)已知接口或者抽象類的實(shí)現(xiàn),而 "服務(wù)提供者" 指的是實(shí)現(xiàn)這些接口或類的具體實(shí)現(xiàn)。

1.1 功能和用途

  • 動(dòng)態(tài)發(fā)現(xiàn)和加載實(shí)現(xiàn): ServiceLoader 可以在運(yùn)行時(shí)動(dòng)態(tài)地查找和加載接口或抽象類的實(shí)現(xiàn),而無(wú)需在代碼中硬編碼它們。
  • 解耦服務(wù)接口和實(shí)現(xiàn): 它允許應(yīng)用程序開(kāi)發(fā)人員將服務(wù)接口與其實(shí)現(xiàn)分離,增加了代碼的模塊化和靈活性。
  • 支持插件機(jī)制: ServiceLoader 常被用于實(shí)現(xiàn)插件架構(gòu),允許第三方為應(yīng)用程序提供擴(kuò)展或自定義功能。
  • 遵循SPI約定: 服務(wù)提供者必須遵守一定的約定,例如在 META-INF/services 目錄下提供特定的配置文件。

1.2 工作原理

  • 服務(wù)定義: 定義一個(gè)服務(wù)接口或抽象類。
  • 服務(wù)實(shí)現(xiàn): 實(shí)現(xiàn)該接口或抽象類。
  • 注冊(cè)服務(wù)提供者: 在類路徑的 META-INF/services 目錄中創(chuàng)建一個(gè)名字與服務(wù)接口全名相同的文件,文件內(nèi)容是實(shí)現(xiàn)類的全限定名。
  • 使用 ServiceLoader: 應(yīng)用程序通過(guò) ServiceLoader 加載服務(wù)接口,ServiceLoader 會(huì)自動(dòng)查找并加載實(shí)現(xiàn)。

1.3 示例

假設(shè)有一個(gè)服務(wù)接口 MyService 和它的多個(gè)實(shí)現(xiàn),可以通過(guò)以下方式使用 ServiceLoader 加載它們:

ServiceLoader<MyService> loader = ServiceLoader.load(MyService.class);
for (MyService service : loader) {
    // 使用加載的服務(wù)實(shí)現(xiàn)
}
  • 1.
  • 2.
  • 3.
  • 4.

1.4 注意事項(xiàng)

  • 類加載器: ServiceLoader 使用當(dāng)前線程的上下文類加載器來(lái)加載服務(wù)提供者。
  • 懶加載: ServiceLoader 通常懶加載服務(wù)提供者,只有在需要時(shí)才加載它們。
  • 錯(cuò)誤處理: 如果服務(wù)提供者不符合要求(如無(wú)法實(shí)例化),ServiceLoader 可能會(huì)拋出 ServiceConfigurationError。
  • Java模塊化: 在 Java 9 及其以上版本中,ServiceLoader 也可以用于模塊化系統(tǒng)中。

ServiceLoader 在許多Java應(yīng)用程序和庫(kù)中都非常有用,尤其是在那些需要靈活性和解耦合的場(chǎng)景中。

二、 SPI的應(yīng)用場(chǎng)景

ServiceLoader 作為一種 SPI 機(jī)制,在許多主流框架中都有應(yīng)用,尤其是在需要插件化或模塊化的場(chǎng)景中。以下是一些具體的使用場(chǎng)景:

應(yīng)用框架/技術(shù)

SPI 使用場(chǎng)景

Spring 框架

用于加載可插拔組件,如 HttpMessageConverters;在初始化上下文時(shí)加載和注冊(cè)服務(wù)和處理器。

Java JDBC API

用于動(dòng)態(tài)加載數(shù)據(jù)庫(kù)驅(qū)動(dòng)。當(dāng)應(yīng)用嘗試連接數(shù)據(jù)庫(kù)時(shí),JDBC API 通過(guò) SPI 動(dòng)態(tài)加載可用的數(shù)據(jù)庫(kù)驅(qū)動(dòng)。

Java Image I/O API

用于動(dòng)態(tài)發(fā)現(xiàn)和加載可用的圖像讀寫器和處理器。

Java 6 及以上版本

SPI 機(jī)制被標(biāo)準(zhǔn)化,用于加載各種類型的服務(wù)接口實(shí)現(xiàn)。

Java Logging API

用于加載日志框架的實(shí)現(xiàn),如可以插拔的日志處理器。

Spring Boot

使用 SPI 機(jī)制發(fā)現(xiàn)和加載自動(dòng)配置類 (@Configuration 類),主要通過(guò) spring.factories 文件實(shí)現(xiàn)。

OSGi

OSGi 框架使用類似 SPI 的機(jī)制來(lái)動(dòng)態(tài)管理模塊,允許模塊在運(yùn)行時(shí)被安裝、啟動(dòng)、停止、更新和卸載。

這些示例展示了 SPI 在現(xiàn)代編程框架和庫(kù)中的廣泛應(yīng)用,突出了其在實(shí)現(xiàn)模塊化、插拔式架構(gòu)中的重要性。

  1. Spring 框架:

Spring框架中的一些部分,例如 spring-web, 使用 ServiceLoader 來(lái)加載一些可插拔的組件,如 HttpMessageConverters。

在Spring框架的上下文初始化過(guò)程中,ServiceLoader 被用來(lái)加載和注冊(cè)各種服務(wù)和處理器。

  1. Java JDBC API:

ServiceLoader 在 Java 的 JDBC API 中用于加載數(shù)據(jù)庫(kù)驅(qū)動(dòng)。當(dāng)一個(gè)應(yīng)用程序嘗試連接數(shù)據(jù)庫(kù)時(shí),JDBC API 通過(guò) ServiceLoader 動(dòng)態(tài)加載可用的數(shù)據(jù)庫(kù)驅(qū)動(dòng)。

  1. Java Image I/O API:

在 Java 的 Image I/O API 中,ServiceLoader 用于動(dòng)態(tài)發(fā)現(xiàn)和加載可用的圖像讀寫器和圖像處理器。

  1. Java 6 中的 java.util.ServiceLoader:

在 Java 6 及以上版本中,ServiceLoader 被標(biāo)準(zhǔn)化,用于加載服務(wù)提供者,如各種類型的服務(wù)接口實(shí)現(xiàn)。

  1. Java Logging API:

在 Java Logging API 中,ServiceLoader 可用于加載日志框架的實(shí)現(xiàn),比如可以插拔的日志處理器。

三、 Spring Boot 對(duì) SPI 的改造和擴(kuò)展

Spring Boot 對(duì) SPI 機(jī)制進(jìn)行了改造和擴(kuò)展,使其成為 Spring Boot 自動(dòng)配置的核心機(jī)制之一。這種改造和擴(kuò)展主要體現(xiàn)在以下幾個(gè)方面:

  1. 自動(dòng)配置:

Spring Boot 使用 ServiceLoader 機(jī)制來(lái)發(fā)現(xiàn)和加載自動(dòng)配置類 (@Configuration 類)。這是通過(guò) spring.factories 文件實(shí)現(xiàn)的,該文件位于每個(gè)自動(dòng)配置模塊的 META-INF 目錄下。

開(kāi)發(fā)者可以通過(guò)在 spring.factories 文件中聲明自己的自動(dòng)配置類,來(lái)擴(kuò)展或修改 Spring Boot 的默認(rèn)行為。

  1. 條件裝配:
  • Spring Boot 的自動(dòng)配置利用了 @Conditional 注解(如 @ConditionalOnClass,@ConditionalOnBean 等),使得僅在滿足特定條件時(shí),相關(guān)的自動(dòng)配置類才會(huì)被激活和應(yīng)用。

  • 這種機(jī)制結(jié)合 ServiceLoader 使得 Spring Boot 能夠在運(yùn)行時(shí)根據(jù)環(huán)境(例如類路徑中的類、定義的beans、系統(tǒng)屬性等)靈活地加載不同的配置。

  1. 擴(kuò)展點(diǎn):

  • Spring Boot 允許開(kāi)發(fā)者通過(guò)添加自己的 spring.factories 來(lái)擴(kuò)展或覆蓋默認(rèn)的自動(dòng)配置,這提供了一個(gè)強(qiáng)大的擴(kuò)展點(diǎn),使得開(kāi)發(fā)者可以根據(jù)自己的需要自定義配置。

通過(guò)這些改造和擴(kuò)展,Spring Boot 極大地簡(jiǎn)化了 Spring 應(yīng)用程序的配置,使得開(kāi)發(fā)者可以快速啟動(dòng)和運(yùn)行基于Spring的項(xiàng)目,同時(shí)也保留了高度的可定制性。這種自動(dòng)配置和條件裝配的方法成為了 Spring Boot 的一個(gè)顯著特點(diǎn)和優(yōu)勢(shì)。

四、 思考與拓展

類似于ServiceLoader的這種SPI機(jī)制,我更愿意稱它為一種框架的插件機(jī)制,因?yàn)樗峁┝艘环N插拔機(jī)制,可以讓第三方開(kāi)發(fā)人員很容易的對(duì)框架進(jìn)行功能的拓展,這種機(jī)制對(duì)原框架的功能和新拓展的功能進(jìn)行了解耦,他們之間通過(guò)接口約定,然后基于SPI進(jìn)行插拔式拓展,非常的靈活。除了 SPI,還有一些其他機(jī)制和模式也被用于擴(kuò)展框架功能,主要包括:

  1. 插件架構(gòu)(Plugin Architecture):

許多現(xiàn)代軟件框架和應(yīng)用程序采用插件架構(gòu),允許第三方開(kāi)發(fā)者通過(guò)插件擴(kuò)展或改變應(yīng)用程序的功能。例如,IDEs(如 IntelliJ IDEA 或 Eclipse)允許通過(guò)插件添加新功能。

插件通常是獨(dú)立于主應(yīng)用程序的,通過(guò)預(yù)定義的API與主應(yīng)用程序交互。

  1. 事件驅(qū)動(dòng)架構(gòu)(Event-Driven Architecture, EDA):
  • 在事件驅(qū)動(dòng)架構(gòu)中,組件之間的通信是基于事件的。這種模式允許應(yīng)用程序在發(fā)生特定事件時(shí)觸發(fā)新的行為,而無(wú)需更改發(fā)出事件的代碼。

  • 這種模式在框架中常用于處理用戶界面動(dòng)作、消息傳遞等場(chǎng)景。

  1. 反射和動(dòng)態(tài)代理(Reflection and Dynamic Proxy):

  • Java中的反射API允許程序在運(yùn)行時(shí)檢查或修改其自身行為。

  • 動(dòng)態(tài)代理是一種常見(jiàn)用法,可以在運(yùn)行時(shí)動(dòng)態(tài)創(chuàng)建一個(gè)接口的實(shí)現(xiàn),用于攔截方法調(diào)用或改變行為,這在一些框架中用于實(shí)現(xiàn)AOP(面向切面編程)。

  1. 依賴注入(Dependency Injection, DI):

  • 依賴注入是一種控制反轉(zhuǎn)(IoC)的形式,常用于框架中管理和配置組件。

  • 通過(guò)依賴注入,框架可以動(dòng)態(tài)地為應(yīng)用程序提供所需的組件,這在Spring等框架中非常普遍。

  1. 組件模型(Component Model):

  • 某些框架提供了一個(gè)基于組件的模型,其中應(yīng)用程序被構(gòu)建為一系列可以獨(dú)立開(kāi)發(fā)和部署的組件。

  • OSGi是這種模型的一個(gè)例子,它提供了一個(gè)動(dòng)態(tài)組件系統(tǒng),其中組件可以在運(yùn)行時(shí)被安裝、啟動(dòng)、停止、更新和卸載。

  1. 模板方法和鉤子方法(Template Method and Hook Method):

  • 在模板方法設(shè)計(jì)模式中,算法的結(jié)構(gòu)由超類定義,而某些步驟則留給子類來(lái)實(shí)現(xiàn)。

  • 鉤子方法提供了在框架的某個(gè)特定點(diǎn)插入自定義行為的能力。

這些機(jī)制和模式都為軟件框架提供了靈活性和擴(kuò)展性,允許開(kāi)發(fā)者在不改變框架核心代碼的前提下增加新的功能或者改變現(xiàn)有功能。這些機(jī)制在現(xiàn)代軟件開(kāi)發(fā)中非常重要,特別是在構(gòu)建可擴(kuò)展、可維護(hù)和模塊化的應(yīng)用程序時(shí)。

分享到:
標(biāo)簽:SPI
用戶無(wú)頭像

網(wǎng)友整理

注冊(cè)時(shí)間:

網(wǎng)站:5 個(gè)   小程序:0 個(gè)  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會(huì)員

趕快注冊(cè)賬號(hào),推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過(guò)答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫(kù),初中,高中,大學(xué)四六

運(yùn)動(dòng)步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動(dòng)步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績(jī)?cè)u(píng)定2018-06-03

通用課目體育訓(xùn)練成績(jī)?cè)u(píng)定