2018/4/16 15:08:46当前位置推荐好文程序员浏览文章

前言

之前对dubbo的SPI进行了四篇的分享.大家对这个概念有了少量初步的理解.谈到编程水平如何进阶,大家可可以都会异口同声的说出三个字,看源码.但是我却始终认为,编程光,是永远学不会的.关键还是要多动手.但是很多时候,连怎样看源码都无从下手,你叫我写仿写源码,这不是开玩笑?

我们能回忆一下我们在公司是怎样写代码的.首先产品提出需求,接着开需求评审会,再接着代码设计,最后开始编码.

今天我们就仿造这个流程,自己动手实现dubbo的spi

提出需求

在 dubbo源码解析-spi(二) 中,我们已经分析了dubbo中spi和jdk中spi有什么区别,dubbo相比jdk变化的内容大致如下:

(一) 拓展点添加了缓存,提高了性可以
(二) 添加了spi的默认值
(三) 添加了通过key的形式获取拓展点
(四) 添加了IocAOP功可以

这里插句题外话,我们不可以为了看源码而看源码,最重要的是,在看源码的过程中,学会分析问题的思路.如果有个新的RPC框架,比方肥朝RPC,我问你肥朝RPC中的SPI和JDK的SPI有几点区别呢?我在dubbo源码解析-spi(二)这篇中,就把我是如何分析出这四点的整个心路历程展现出来,你能大胆走进我的内心世界.

需求评审

既然是需求评审,其实说白了,就是和产品砍需求.产品提出的需求就是上面那四个功可以.(一)(二)(三)都是基本又比较核心的功可以,这些砍了那这个版的本就没意思了,(四)这个能放在下一个版的本去迭代开发.

代码设计

只需实现了key-value获取拓展点,那么获取默认拓展点就很容易了,由于这个默认拓展点只是key-value的一种特殊形式,他的默认值,也就是这个key,就在SPI注解上.其实思路总起起来就一句话,由于我们在拓展点配置文件里面已经配置了实现类的权限定名.首先我们把这些配置文件一律加载出来,解析出全限定名,缓存起来.而后你要获取具体的拓展点,我就在缓存中把他的权限定名拿出来,反射实例化成一个对象返回回去.也就是1.读取并解析文件内容 2.放入map缓存 3.反射生成对象.这三个知识点,我相信看这篇文章的,没有人不会.

按照上面的分析,把代码写出来不难吧.什么,写不出?那往下看

编码

项目结构如图:

运行结果如图

代码已经上传到码云.能下载跑起来,原本想消耗时序图,流程图和大家把思路理一下的,但是弄了几个小时,我觉得还不如自己看代码清楚.核心代码代码不到300行.有问题能留言.

地址: https://gitee.com/HelloToby/tobySPI

克隆/下载按钮,而后下载ZIP,而后导入eclipse或者者idea即可以运行了.

小提醒

由于之前部分同学反馈对源码中的思路还不是很清晰.所以这次我就直接把源码中的功可以板块抽成一个demo,而后大家先把demo运行起来,接着把demo里面的代码重复写个一两遍.由于demo和源码一比一高仿的(变量名,方法名甚至if换不换行都尽量一致了).所以这个时候,再去看源码就和看自己写的代码应该一样的.这样思路就清晰很多了.希望这个方式对你阅读源码有帮助.

写在最后

这个是停更两个月后,回归的第一篇文章.因为公司的某些起因,接下来可可以无法像去年一样,每周一更.但是尽量保证,两周一更.但是即便两周一更,也会每周不断学习提升自己,给大家带来更好的分享.但是鉴于肥朝才疏学浅,文中不足之处还望你不吝斧正.也欢迎关注我的简书,名称为肥朝.

上一篇 目录 已是最后
网友评论