阅读枯燥源码指南

一个软件开发人员,工做到了必定的年限(通常是三、4年左右),若是他还没学会阅读源码,那么他就会遇到瓶颈。由于到了这个时候的开发,他应该不只仅只会作那些 CURD 的业务逻辑,而应该会根据公司的实际状况去写框架。java

而基本上没有谁能像天才同样从零写出一个框架,不少人写框架其实都是从模仿开始的。而你要模仿,那么你首先得看得懂框架源码才行。因此说阅读源码才显得那么重要。app

我在工做一两年的时候有尝试去看过 JDK 的源码,那时候感受就跟看天书同样,看一点都以为痛苦。一直到工做三年左右,由于同事都在看源码,我也开始看一些源码。框架

我看的第一个框架的源码是 dubbo,虽说没有彻底搞懂它。可是经过阅读 dubbo 源码,我弄懂了 JDK 的 SPI 机制,知道 SPI 在框架开发中的做用。一直到最近阅读公司的一个网关框架,我才慢慢有一点阅读源码的经验和套路。正好趁热打铁,把这些经验写下来,但愿大家也能早日踏上源码阅读之路。ide

搜索网上资料工具

阅读一个框架的源码,最基础的操做确定是扫一遍网上的各类分析文章。经过这个操做,你能够对这个框架有个大体的了解。站在巨人的肩膀上,少走许多弯路。但若是你看的项目是公司内部的框架,那么你只能找公司内部的文档了,更甚者,有些连文档都没有。那么你能够略过这一步。ui

扫一遍源码spa

当你拿到框架的源码的时候,你能够大体把源码的每一个包,以及每一个包下面的文件扫读一遍。扫读并不须要你弄清楚每一行代码的意思,只须要让你知道源码每一部分的做用。插件

若是一个开源框架足够标准,那么他的命名是很是语义化的。因此咱们扫读的时候,经过包名、文件名就能够判断出这个包是用来干吗的。设计

例如 util 包是工具类,那咱们能够直接跳过。vo 包是存放实体模型的,一样能够跳过。protocol 包是存放协议相关的等等。经过这么一个步骤,你会对整个项目有一个基本的印象,知道这个项目大概有哪些东西,哪些相对比较重要。3d

找到入口

阅读任何一个框架的源码,首先就是要找到框架的入口。经过上面扫读源码,你应该可以发现一些入口的迹象,例如对于 Dubbo 来讲,你会发现它有一个名为 dubbo-demo 的子模块,那么咱们确定重点看它。

进一步发掘需求你会发现它的入口就是 dubbo-demo 中的 Provider 类、Consumer 类。咱们能够直接接运行这两个类的 main 方法,并一步步跟踪代码的执行状况。

通读源码

找到入口以后,下一步就是通读全部源码了,就是把源码的每一个文件每一行都看一遍。在这个阶段不求彻底弄懂细致的业务逻辑,可是要造成一个大概的框架,知道这个框架是如何设计的,有哪些大体的模块,这些模块是如何设计的。

在通读源码这个阶段是最枯燥无味的,也是最容易放弃的。一方面由于源码实在过于多,另外一方面由于没有一个目标,因此看着看着内心没有底,因此容易放弃。我一开始也是如此,但以后我想出了一个比较好的办法,经过数字化的方式让本身知道阅读进度。这样本身就不会以为内心没底,不知道要多久才能看完了。

个人方法是给个人 IDE 装一个代码统计插件:Statistics。这个插件可以统计项目中的源码行数。例以下面是我统计 dubbo 项目源码的截图,它会列出每一个 java 文件的源码行数,以及总共的行数。

fc258b990dbfb71186bf6e24bb6cdeec557b89f3

从上面的截图咱们能够看到 dubbo 项目里,源码的行数有 11 万行。这样一来,本身心理也有个大体的预期了。

接下来,我会把这些数据拷贝出来,放在一个 Excel 表格里,就像下面这样子:

22a0fe023b3c5d07a204bf88919742bcc9a2059a

在 Excel 表格中,我只会存放每一个源码文件的名字、其源码行数、源码行数占比。接下来我会按着入口,一个个去看源文件,把每一个方法看过一遍,看过的方法我会写一个注释,例如:csy mark,并写上个人注释。

当我把一个文件都看过以后,我会把 Excel 表格中对应的文件最右边一列,写上其百分比。最后我会在下边有一行,统计我所看完文件的百分比。

e6db83dfcf83f693e7cb2cb32729fe6afed3ce58

我每看完一个方法,我就写一个 csy done 来鼓励下本身。每看完一个文件,我就在 Excel 中把它标记为完成,最下边的已读百分比也会跟着不断升高。经过这种方式,我让枯燥无味的源码阅读,有些一点趣味,有了一些目标。

通读源码是最枯燥的,最容易没有方向和目标的。有了数字化的记录,你能够知道本身如今的进度是怎么样,看了多少的源码。不少时候咱们看了好久,发觉没什么进度的样子,又不想看了。

这时候你能够给本身定一个目标,例如:一天看完 5% 的源码就能够休息。那当你想偷懒的时候,看看 Excel 下方的已读百分比,还没到 5%,继续看吧。

这种方式对于我来讲,仍是有必定做用的。但对于大家不知道有没有做用,大家能够尝试一下。若是有用的话,就来评论告诉我吧。

梳理框架

在通读源码的过程当中,你就会对框架有许多新的认识,会知道这个框架大体分为哪几个部分,每一个部分的做用是什么,这个模块用了什么设计理念等等。

若是说上个阶段是通读源码,那么这个阶段就是要把你在通读源码过程当中的收获整理出来。在整理的过程当中,你确定会有更多的疑问,你会不断地细化,不断地精读。

批判性思考

经过了上面几个阶段,你会发现你对这个框架有了总体的认识,而且对每一个模块的实现细节都有了比较深入的认识。这个时候,你能够想想为何它要这么作,这么作有什么好处,那能用另外一种方式作得更好吗?

总结

上面几个阶段是我阅读几个框架源码以后的一些体会,相信会是一个不错的源码阅读指南。若是你有更好的源码阅读经验或方法,欢迎留言与我交流。


本文做者:陈树义

本文:https://yq.aliyun.com/articles/638580?spm=a2c4e.11153959.teamhomeleft.64.34074b0frd1whW

相关文章
相关标签/搜索