JAVA-SPI(dubbo的基石)实现原理
2020-01-04 本文已影响0人
秃秃少年小猪
1:SPI--- Service Provider Interface : 服务提供接口,结构图如下:
2:本质:JavaSPI 实际上是“基于接口的编程+策略模式+配置文件”组合实现的动态加载机制.
3:实现原理
3.1:首先解决第一个疑问,为什么这个spi的配置文件要放在classpath:META-INF/services下面
这个ClassLoader决定了从哪里加载文件
3.2:实现原理,通过读取到spi文件里面的内容(service),然后通过ClassLoader进行类加载,从而是是实现动态的的类加载
有个很有趣的点,如下
首先会判断当前类加载器是否为Null,要是为null的话,这个类肯定没有被加载过,使用ClassLoader加载,可以避免重复加 载,这点和”双亲模型“前后呼应,要是加载过的话,直接使用当前类的类加载器去就OK了。在全部加载完毕后 ServiceLoader会提供静态方法load给外部使用,如下图
3.3:总结:java的SPI的机制是jdk提供的类加载机制实现的, 在dubbo中,也是基于SPI,只不过是java-spi的增强.