Java ServiceLoader toString() 方法



描述

java ServiceLoader toString() 方法返回一个描述此服务的字符串。

声明

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

public String toString()

参数

返回值

此方法返回一个描述性字符串

异常

获取 ServiceLoader 实例的字符串表示形式示例

为了注册服务,我们需要在类路径中有一个 META-INF/services 文件夹。在此特定文件夹中,我们需要一个文本文件,其名称为我们正在实现的接口,其中包含一行列出实现的具体类名。在我们的例子中,文件名为 com.tutorialspoint.ServiceProvider,并且包含以下行:

com.tutorialspoint.ServiceImplementation

我们的服务代码如下:

package com.tutorialspoint;

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

以下代码加载已注册的服务并使用它从服务获取消息。我们创建了一个 getDefault() 方法,它返回一个 ServiceProvider。此方法使用 ServiceLoader.load() 获取一个 serviceLoader 对象。使用 serviceLoader.toString() 方法,我们打印了服务加载器的字符串表示形式。然后迭代 serviceLoader 并返回第一个提供程序。最后,如果未返回提供程序,则抛出错误。然后使用 getDefault() 我们检索了 serviceProvider 并使用此对象打印了消息。

package com.tutorialspoint;

import java.util.ServiceLoader;

public abstract class ServiceProvider {

   public static ServiceProvider getDefault() {

      // load our plugin
      ServiceLoader<ServiceProvider> serviceLoader =
         ServiceLoader.load(ServiceProvider.class);

      // print the serviceLoader as a string
      System.out.println(serviceLoader.toString());

      // 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());
   }
}

输出

让我们编译并运行上述程序,这将产生以下结果:

java.util.ServiceLoader[com.tutorialspoint.ServiceProvider]
Hello World
java_util_serviceloader.htm
广告

© . All rights reserved.