API与SPI

作者: 简xiaoyao | 来源:发表于2017-10-28 19:38 被阅读333次

    在看dubbo源码的时候,发现里面大量的使用了SPI机制,而对于很多的人来说,SPI还是一个相对陌生的概念(我也是看dubbo源码以后才详细了解什么是SPI),而API则不然,大家或多或少都有了解,之所以将这两个概念放到一起阐述,也是因为大部分人在初次接触SPI时经常会有这样的疑惑:啥是SPI?和API有啥关系?本文将对这两个概念分别进行阐述并分析其主要的区别,一来让不了解SPI的人能在读完此文后知道SPI为何物,二来也夯实一下对API的理解

    compare.png

    概念阐述

    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一般被应用开发人员使用,由实现方实现
    • API是一类classes/interfaces/methods,它们提供特定的功能接口,以供实现;SPI一般被框架开发人员使用,调用方与实现方都可提供SPI的实现

    使用场景

    需要清楚的一点是API与SPI主要是概念上的区分,具体代码上并没有严格的界限,有的时候一个接口既可以是API也可是同时是SPI,如JDBC中的Connection接口,你可以作为调用方直接使用该接口实现数据库连接(API),同时你也可以作为实现方提供其它的实现以替换其原有的连接方式(SPI);最后,如果希望对SPI有更进一步的了解可以参考Java官方对SPI的定义与使用介绍

    相关文章

      网友评论

        本文标题:API与SPI

        本文链接:https://www.haomeiwen.com/subject/vtisyxtx.html