首先定义接口MyService,然后在META-INF/services下创建以接口全限定名为名的文件并写入实现类名,接着编写实现类MyServiceImpl,最后通过ServiceLoader加载并调用execute方法。

Java SPI(Service Provider Interface)是一种服务发现机制,用于定义接口并让第三方提供实现。要使用 SPI,需要按照约定的规则来定义接口和配置实现类。
定义接口
在项目的 src/main/java 目录下创建一个接口,比如:
public interface MyService {void execute();
}
这个接口就是服务提供者需要实现的契约,它通常放在你发布的库中,供外部扩展使用。
创建 META-INF/services 配置文件
SPI 的核心是通过配置文件告知 JVM 哪些类实现了该接口。你需要在 src/main/resources 下创建目录 META-INF/services,然后创建一个以接口全限定名为名称的文件:
立即学习“Java免费学习笔记(深入)”;
- 文件路径:META-INF/services/com.example.MyService
- 文件内容:写入实现类的全限定名,例如:
com.example.impl.MyServiceImpl
如果有多个实现类,每行写一个实现类名。
何利用jQuery插件leanModal建立一个常规模态窗口。如果你有MIT general license,那么这个插件是完全开源和免费的,我很喜欢这个插件,用起来相当方便,还能自行添加CSS,达到自定义的效果。
编写实现类
实现类必须有一个无参构造函数,以便 ServiceLoader 能够实例化它:
package com.example.impl;import com.example.MyService;
public class MyServiceImpl implements MyService {
@Override
public void execute() {
System.out.println("MyService 执行了");
}
}
使用 ServiceLoader 加载实现
通过 Java 标准的 ServiceLoader 来加载所有实现:
ServiceLoaderfor (MyService service : loader) {
service.execute();
}
运行时,JVM 会自动查找所有 jar 包中 META-INF/services 下的配置文件,并加载对应的实现类。
基本上就这些。只要接口定义清楚,配置正确,就能实现灵活的插件化架构。注意不要遗漏资源文件路径或类名拼写错误。










