Java獲取接口所有實現(xiàn)類的方式詳解
有時候,根據(jù)業(yè)務邏輯的需求,我們想要獲取到某個接口的所有實現(xiàn)類。在這里大致介紹兩種方式:
1.借助Spring容器實現(xiàn)
Spring作為一個容器,管理著一個項目中所有經(jīng)過配置的Java類(xml配置文件或Annotation方式)。如果某個接口的所有實現(xiàn)類均被Spring托管了,那么通過Spring就可以很簡單的返回這些實現(xiàn)類。
import org.springframework.beans.BeansException;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.stereotype.Component;
@Component
public class ServiceLocator implements ApplicationContextAware{
/**
* 用于保存接口實現(xiàn)類名及對應的類
*/
private Map<String, IService> map;
/**
* 獲取應用上下文并獲取相應的接口實現(xiàn)類
* @param applicationContext
* @throws BeansException
*/
@Override
public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
//根據(jù)接口類型返回相應的所有bean
Map<String, IService> map = applicationContext.getBeansOfType(IService.class);
}
public Map<String, IService> getMap() {
return map;
}
}
2.借助ServiceLoader類
ServiceLoader是JDK自帶的一個類加載器,位于java.util包當中,作為 A simple service-provider loading facility. 具體使用方式如下:
1.在META-INF/services/目錄下用你的接口全路徑名稱命名一個文件(不加后綴),然后在該文件中一行一個添加你的接口實現(xiàn)類的全路徑名。
2.通過load方法來加載出所有的接口實現(xiàn)類
ServiceLoader<MyInterface> loader = ServiceLoader.load(MyInterface.class);
在這里load方法的返回值是一個迭代器,用這個迭代器可以遍歷出所有的接口實現(xiàn)類。
總結(jié)
以上兩種方式,實現(xiàn)的功能都是一樣的,實現(xiàn)方式不同,底層用的技術(shù)一樣的,都是反射。至于選擇哪一種,我建議如果項目中的接口實現(xiàn)類都被Spring托管了,那當然是直接用Spring了。如果沒有用到Spring的話,那就用ServiceLoader,這個肯定是沒有問題的。希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Spring Boot加密配置文件特殊內(nèi)容的示例代碼詳解
這篇文章主要介紹了Spring Boot加密配置文件特殊內(nèi)容的相關(guān)知識,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-05-05
如何更優(yōu)雅的關(guān)閉java文本、網(wǎng)絡等資源
這篇文章主要介紹了如何更優(yōu)雅的關(guān)閉java文本、網(wǎng)絡等資源,在 finally 的關(guān)閉代碼中,還要再來一個 try/catch,看著是不是很難受,很不優(yōu)雅,很想干掉這個 finally!,需要的朋友可以參考下2019-06-06
Springboot中使用Filter實現(xiàn)Header認證詳解
這篇文章主要介紹了Springboot中使用Filter實現(xiàn)Header認證詳解,當在?web.xml?注冊了一個?Filter?來對某個?Servlet?程序進行攔截處理時,它可以決定是否將請求繼續(xù)傳遞給?Servlet?程序,以及對請求和響應消息是否進行修改,需要的朋友可以參考下2023-08-08
Java Web基于Session的登錄實現(xiàn)方法
這篇文章主要介紹了Java Web基于Session的登錄實現(xiàn)方法,涉及Java針對session的操作及表單提交與驗證技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-10-10

