API 与 SPI
API(Application Programming Interface)
目标:为使用者提供功能 ------- 是服务提供者(如库、框架)向使用者暴露的一组接口,定义了如何调用特定功能或访问资源。
核心思想: 隐藏实现细节,使用者只需要关注接口定义。
例如:
Java中的 java.util.List 接口 ( 如 add,get 方法)
Spring Framework 的 @Autowired 注解 (实现依赖注入)
SPI(Service Provider Interface)
目标:为服务提供者定义扩展点,是框架或库向第三方服务提供者暴露的接口,允许第三方为某个功能提供具体实现。
核心思想:框架解耦与具体实现,支持动态扩展
示例:
Java的JDBC(通过DriverManager加载数据驱动)
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;public class JdbcExample {public static void main(String[] args) {// 1. 加载数据库驱动(传统方式)try {// Class.forName("com.mysql.cj.jdbc.Driver"); // 旧版驱动(JDBC 4.0 前)Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/testdb", "username", "password");System.out.println("连接成功!");conn.close();} catch (SQLException e) {e.printStackTrace();}}
}
总结
两者都是接口,处于服务调用方(用户)和服务提供者中间:当服务提供者提供了接口和实现,我们可以通过调用实现方的接口从而拥有服务提供者给我们提供的能力-----API。在此情况下,接口和实现都是放在服务提供者的文件(包)中,服务调用方通过接口调用服务提供者的功能,就不需要关心具体实现。
当接口存在于调用方这边时(调用方通过暴露的接口来对其进行具体实现),这就是SPI。由接口调用方确定接口规则,然后由不同的厂商根据这个规则对这个接口进行实现,从而提供服务。
例子:别人给我一个魔方,让我将魔方复原-----别人调用我的能力-----API
别人确定好复原魔方的规则,让我基于这个规则下复原魔方------别人制定规则后又通过我的能力实现-----SPI