SPI是JDK内置的一种服务提供发现机制,主要作用是用来做服务的拓展实现,其实在平常开发中,我们就已经接触到了SPI机制,只是我们没有太关注,比如数据库连接,JDK提供了一个java.sql.Driver接口,这个驱动在JDK中没其实没有实现,而是由不同的数据库提供商来实现的,比如MySQL这些数据库驱动其实都会实现这个驱动类,当然SPI也是有一定的协议约定,比如所有的拓展点必须要放在resources/META-INF/services目录下,SPI机制就会默认去扫描这个路径下的属性文件,然后完成加载
1、创建maven或者springboot项目,命名为spi-driver,然后定义一个驱动接口类Driver,这个接口相当于上面说的java.sql.Driver,只是一个约定或者规范,但是没有实现,需要我们自己来实现
public interface Driver{
String connect();
}
2、然后再创建一个maven或者springboot项目,命名为spi-mysql-driver,添加上上面接口对应的pom依赖,并实现Driver接口逻辑
public class MysqlDriver implements Driver{
@Override
public String connect(){
return "MySQL驱动初始化,加载连接数据库!";
}
}
3、在spi-mysql-driver工程中的resources/META-INF/services目录下创建一个以Driver接口全路径命名的文件
文件名称是:com.cb.spi.Driver
文件配置是:com.cb.spi.impl.MySqlDriver
4、创建一个main方法进行测试,使用ServiceLoader加载上面的拓展点,代码如下:
public class SpiTest{
public static void main(String[] args){
ServiceLoader<Driver> serviceLoader=ServiceLoader.load(Driver.class);
serviceLoader.forEach(driver -> System.out.println(driver.connect()));
}
}
---------------------------------------------------------------------------
输出:MySQL驱动初始化,加载连接数据库!