目录

public static <S> ServiceLoader<S> load(Class<S> service, ClassLoader loader)

描述 (Description)

java.util.ServiceLoader.load(Class《S》 service,ClassLoader loader)方法为给定的服务类型和类加载器创建新的服务加载器。

声明 (Declaration)

以下是java.util.ServiceLoader.load()方法的声明

public static <S> ServiceLoader<S> load(Class<S> service,ClassLoader loader)

参数 (Parameters)

  • service - 表示服务的接口或抽象类

  • loader - 用于加载提供程序配置文件和提供程序类的类加载器,如果要使用系统类加载器(或者,失败,则使用引导类加载器),则为null

返回值 (Return Value)

此方法返回一个新的服务加载器

异常 (Exception)

NA

例子 (Example)

为了注册服务,我们需要在类路径中使用META-INF/service文件夹。 在这个特定的文件夹中,我们需要一个文本文件,其中包含我们实现的接口的名称,其中包含列出实现的具体类名的单行。 在我们的例子中,该文件的名称是com.iowiki.ServiceProvider并包含此行 -

com.iowiki.ServiceImplementation

我们的服务代码如下 -

package com.iowiki;
public class ServiceImplementation extends ServiceProvider {
   public String getMessage() {
      return "Hello World";
   }
}

以下代码加载已注册的服务并使用它来从服务获取消息 -

package com.iowiki;
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
↑回到顶部↑
WIKI教程 @2018