前言
Android开发人员都知道,阅读源码是非常好的学习方式,在我们日常工作中或多或少都会接触一些开源代码,比如说最常用的Retrofit 、 OkHttp、MMKV,这些源码的普及与应用程度远远超过我们的想象。但是,纵观我们身边的人,能够做到通读源码的真的是少之又少,究其原因,不外乎以下几点。
1. 源码的复杂性:任何一款源码都经历了多年的发展与提炼,其复杂程度可想而知。当阅读源码时,通常需要通过工具跟踪代码的运行,进而去分析程序。然而,当代码过于复杂,环环相扣且涉及大量函数时,即使跟进了几十个甚至几百个函数后,人们也可能不知道自己所处的位置,不得不重来。反复尝试后,可能会发现自己根本无法驾驭它,不得不放弃。
2. 遇到的问题和解决方案:有些源码发展多年,会遇到各种各样的问题,并对问题进行了解决。然而,其中有些问题对于我们来说可能难以理解,甚至可以用莫名其妙来描述。在查阅各种资料后,如果仍然无法找到答案,人们可能会失去耐心,最终选择放弃。
3. 时间和精力限制:通读源码需要投入大量的时间和精力。在忙碌的工作和生活节奏下,开发者很难找到大量的连续时间来阅读源码。零碎的时间对于通读源码来说是不够的,而需求变化又使得开发者需要不断地调整工作,很难有足够的时间和精力去深入阅读源码。
4. 缺乏动力和目标:如果没有明确的目标或者动力去阅读源码,那么开发者很可能会放弃。他们可能认为只需要了解如何使用某个库或框架,而不需要深入了解其实现细节。
- 文档不足:如果一个开源项目没有提供足够的文档,那么开发者就需要花费更多的时间去理解源码,这可能会让他们失去耐心和动力去深入阅读。
更重要的是
读源码并不是一件简单的事情。难在哪里?因为读源码不是简单的把源码看一遍,而是要去了解为什么这么写?这样写的目的是什么?为什么不那样写?
而要自发地思考这些问题是很难的,这不仅需要技术水平的高低,还需要对这个框架“历史”的理解,以及理解代码的深度。