在看dubbo源码的时候,发现里面大量的使用了SPI机制,而对于很多的人来说,SPI还是一个相对陌生的概念(我也是看dubbo源码以后才详细了解什么是SPI),而API则不然,大家或多或少都有了解,之所以将这两个概念放到一起阐述,也是因为大部分人在初次接触SPI时经常会有这样的疑惑:啥是SPI?和API有啥关系?本文将对这两个概念分别进行阐述并分析其主要的区别,一来让不了解SPI的人能在读完此文后知道SPI为何物,二来也夯实一下对API的理解
概念阐述
API,英文全称:Application Programming Interface;中文翻译:应用程序接口;它是软件系统不同组成部分衔接的约定,虽然API的英文名称中包含了Interface
,但是API却是classes/interfaces/methods
这一类概念的总称,API的主要作用在于为调用方提供某个功能实现的调用入口,调用方不需关心该API的实现方式如何,它只需知道API可以提供特定的服务功能即可,具体实现由实现方负责
SPI,英文全称:Service Provider Interface;中文翻译:服务供给接口;它是JDK定义的一种服务提供发现机制,主要作用在于为同一服务的提供不同实现的替换机制,这里的服务也是classes/interfaces/methods
这一类概念的总称,该服务的实现可以有多个,而SPI的作用在于为服务的多个版本提供管理(主要是发现与加载),服务可以由第三方提供实现,也可以由调用方提供实现
总结来说,两者的区别可以用下面通俗易懂的话来阐述:
- API是一类
classes/interfaces/methods
,它们提供特定的功能接口,以供调用;API一般被应用开发人员使用,由实现方实现 - SPI是一类
classes/interfaces/methods
,它们提供特定的功能接口,以供实现;SPI一般被框架开发人员使用,调用方与实现方都可提供SPI的实现
使用场景
需要清楚的一点是API与SPI主要是概念上的区分,具体代码上并没有严格的界限,有的时候一个接口既可以是API也可是同时是SPI,如JDBC中的Connection
接口,你可以作为调用方直接使用该接口实现数据库连接(API),同时你也可以作为实现方提供其它的实现以替换其原有的连接方式(SPI);最后,如果希望对SPI有更进一步的了解可以参考Java官方对SPI的定义与使用介绍