java.util.ServiceLoader.load(Class<S> service,ClassLoader loader)方法實例
java.util.ServiceLoader.load(Class<S> service,ClassLoader loader) 方法創建新的服務加載器給定服務類型和類加載器。
聲明
以下是java.util.ServiceLoader.load()方法的聲明
public static <S> ServiceLoader<S> load(Class<S> service,ClassLoader loader)
參數
-
service -- 接口或抽象類表示服務
-
loader -- 類加載器用於加載提供者配置文件和提供者類,或null,如果係統類加載器(或者,做不到這一點,引導類加載器)是用來
返回值
此方法返回一個新的服務加載器
異常
-
NA
例子
為了要注冊的服務,需要在類路徑中META-INF/service文件夾。在這個特殊的文件夾,需要與實現包含單個行列出執行的具體類名的接口的名稱的文本文件。在例子中的文件的名稱是com.yiibai.ServiceProvider和包含這一行:
com.yiibai.ServiceImplementation
我們的服務代碼如下:
package com.yiibai; public class ServiceImplementation extends ServiceProvider { public String getMessage() { return "Hello World"; } }
下麵的代碼加載是注冊並使用它來從服務得到消息的服務:
package com.yiibai; import java.util.ServiceLoader; public abstract class ServiceProvider { public static ServiceProvider getDefault() { // load our plugin with the default system class loader ServiceLoader<ServiceProvider> serviceLoader = ServiceLoader.load(ServiceProvider.class, ClassLoader.getSystemClassLoader()); //checking if load was successful for (ServiceProvider provider : serviceLoader) { return provider; } throw new Error("Something is wrong with registering the addon"); } public abstract String getMessage(); public static void main(String[] ignored) { // create a new provider and call getMessage() ServiceProvider provider = ServiceProvider.getDefault(); System.out.println(provider.getMessage()); } }
讓我們來編譯和運行上麵的程序,這將產生以下結果:
Hello World