看大牛是如何阅读JDK源码,涨涨见识
如何阅读源码,是每个程序员需要面临的一项挑战。 为什么需要阅读源码?从实用性的角度来看,主要有三个目的:第一,解决手头的新问题或者新需求;第二,真正理解一部分理论的落地实现;第三,应对面试。 端正心态 在准备投身到阅读源码的事业之前,首先需要端正一下心态:
在此,我更推荐把源码阅读当成是一项兴趣爱好去做,就好比有的人通过打游戏看直播放松,有的人通过刷新闻追热剧放松,还有的人通过找朋友吹牛逼放松...不同的人会选择不同的劳逸结合方式,我更喜欢不写代码的时候,通过看别人的代码来放松。 作为一名Javaer,朝夕相处的JDK自然是你遇到的第一处宝藏之地。从阅读JDK代码出发,可以深入理解Java的一些新老特性,并学习部分设计模式的应用,以及为将来阅读更庞大的框架打下扎实的理论基础与顽强的心理基础。 选择工具 工欲善其事必先利其器,起步之前,需要先选择一款源码阅读工具。在工具的选择上,同行的建议很多,我大致将其分为四类:
从个人喜好讲,我推荐IDEA和UEStudio(搭配UltraFinder)配合使用。 IDEA作为强大的Java生产工具,用来阅读Java源码显然再合适不过。而UEStudio可以作为临时查看Java文件或者查看JDK中部分C++代码时的选择,再搭配UltraFinder,实现跨文件的任意符号搜索,很实用。 关于阅读环境的搭建,参见我在https://github.com/kangjianwei/LearningJDK中的描述即可。 阅读顺序 JDK的项目历经了十几个大版本,算上开源社区的贡献,经手的人可能也达到上千人。对于这种庞大的项目,一次性读完肯定是不可能,必须先找到一个恰当的入口,分模块来一点点啃完。 可能的一种阅读顺序是:
注意,这里说的顺序只是一个大致的方向,并不代表需要绝对按照这个名单来。 在阅读某一个代码时,往往会牵涉到很多别的代码,这个时候就会产生很多阅读分支,分支的走向,并不在上述名单之内。 善用技巧 阅读代码的技巧,因人而异。就像一千位读者,就有一千部哈姆雷特,每个人对这件事的看法并不相同。在此,我只谈下个人的一些经验。 理论先行。阅读某一个模块时,先搜索它的理论支撑,甚至可以先看别人的阅读经验,有了一个大致的了轮廓之后,自己再去实践。 必须试用。面对一个新的类,最好是先搜索一下它的基本用法,写成一个小的示例,并从这个示例中用到的方法入手,去分析这个类。 巧用调试。关于IDEA中debug的使用方式,超出了本文的讲述范围。值的注意的是,除了需要学习常用的运行时调试,还需要学习编译时调试,这个在阅读Java语言模型那块的代码时很有用。 分清主次。类与类之间呈网状结构,在阅读某个类的时候,不可避免地需要先去阅读它引用的其他类。但是,如果它引用的类很复杂,则建议先放一放,做个标记,回头再读。不过,如果在阅读多个类时,其调用链最终都指向了同一个类,那么这个类就必须先拿下了。 业务为先。如果一个类太过庞大,则先将其中的方法按功能归类,捋清大致的执行流程,接下来再逐个功能地去攻克。 不求甚解。有些方法不需要搞清楚实现过程,只需要了解它的作用。比如一些特定领域的算法,对某些规则的解析等。 (编辑:ASP站长网) |