美文网首页Android开发Android开发Android技术知识
Android进阶之旅 - 源码阅读的经验总结

Android进阶之旅 - 源码阅读的经验总结

作者: 红橙Darren | 来源:发表于2018-07-21 01:00 被阅读58次

    在长沙待的那些年,身边所看到的大概可分为两类人,一类是不断反复的做业务逻辑,只求功能能够写出来,每天重复上下班,不想过多的去折腾;还有一类是不断的反思总结和学习,不只停留在做的层次上,是真正的喜欢做这行,且觉得非常有意思。没有什么好与坏,只是大家的追求不同而已。但如果我们想要去大一点的公司,或者找一份工资稍微高些的工作,后面我们就会有很多坎要去迈,其中一个就是阅读源码,所以这期我们主要来探讨一下阅读源码的 一些姿势。在真正踏上这条路之前,希望我们能明确以下几点:

    • 没有人一上来就可以看得懂源码,我们都是从 Hello World 开始的,所以没有什么捷径可以走,无非就是看我们谁花的时间多,谁更愿意折腾。

    • 大家都是上下班,为啥别人工资拿得高福利又好,而自己大小周,偶尔还需要加班通宵。同样三四年别人拿 20k,我自己却只拿了 10k。注意我说的是 20k ,之前写过一篇文章 《从3K到30K,23岁的年纪我到底经历了什么》 这次同样怕某些哥们会喷,哪有那么高?我们心中要有美好的信念,要有不断向上的激情。

    • 能力提升过程中我们能从中获得很多东西,内心也会变强大,关键是我们在做项目的过程中,的确会要顺手很多,这就可以拿来换钱和时间,前提是我们愿意拿时间去换。

    以上说的可能有些片面,有哥们可能会想哪里来那么多时间和精力?拿我自己来说工作日每天上下班,平时要花时间学习,周末要备课讲课。算算时间并不是很多,但是我们只要下定决心,有规划且能静下心来,时间总是会有很多的。

    一.常用工具


    首先来介绍一些看源码的工具,第一个就是我们的开发工具 Android Studio ,这里我们以具体的示例来说,假设现在我想看 setContentView 的源码,那么我们可以直接跟进到源码的方法里面去:

    这时如果再往里面跟发现是一个抽象类,我们必须要找到实现类,一般来讲我们可以搜索(ctrl + F)找到其创建实例的地方:

    是红色的,这个时候我们再也没法往里面跟了(一碰到红尴尬症就犯了,肾得慌),碰到这种情况我们可以试试全局的搜索(双击 shift)

    但很多情况下我们全局搜索也搜索不到,接下来给大家介绍第二个工具,我们可以在线浏览源码阅读:http://androidxref.com 这里面不光有 Java 层的源代码还有 native 层的源代码

    在线查看一般都是比较精确要看哪个类的时候,并不能满足我们快速查看的需求。我就想在 Android Studio 中看,可以不断快速的往下跟进。其实我们在下载 sdk 的时候一般都会下载源码,只不过刚好 android.jar 包中没有这个 class 类的源码,所以我们才找不到而已。这个时候我们需要一个比较完整的 android.jar ,用来替换我们 sdk 中的 android.jar 文件,关键是这个 jar 怎么来?最好的方式是自己去编译,但很多哥们可能觉得自己编译成本高,那么我们也可以去 github 上下载。https://github.com/anggrayudi/android-hidden-api 把原来保存一份改下命名,把下载的复制进去,然后重启 Android Studio 再去看看,发现不仅没有报红而且可以点击了。

    到后面这些还是无法满足我们的需求,比如现在我们已经把 C++ 进阶学完了,我想跟到 native 层的源码去看看,比如去看看底层的 Binder 驱动,或者去看看类的加载机制,我再送大家一个链接,里面所有的源码基本都能找到:https://pan.baidu.com/s/1tGtBt5Y1G50yI10EkVRPAw

    再啰嗦几句,如果我们对源码非常感兴趣,我建议大家还是自己去编译源码,这样我们就可以利用 Android Studio 去调试跟踪源码,屡试不爽。

    二.前辈力量


    文章的开头跟大家明确说了,没有人一上来就可以看得懂源码,我们都是从 Hello World 开始的,所以没有什么捷径可以走,无非就是看我们谁花的时间多,谁更愿意折腾。别看网上有很多大牛写了很多分析源码的文章,但其实他们都是经过反复折腾,才能写出那一篇形如流水却很抽象的文章。所以我们写了那么多分析源码的文章,录了那么多直播课程,无非就是我们在背后花了很多时间而已。只要你愿意我能行的,你也能行。

    当然刚一开始我并不建议大家自己去看源码,我记得自己第一次看源码的时候,点击进去是一脸蒙 B。所以刚一开始我们需要借助前辈的力量,跟着大牛的思路去看源码,也就是大家通常所说的老司机带带我。

    有几点需要提醒大家是,有些文章可能篇幅比较长,要有耐心不断反复的多看几遍。当然有时也不必在一棵树上吊死,其他树上也可以多试几次。其次我们找一些稍微靠谱一点的,阅读量多一些的文章,排版稍微好点,图文并茂的。最后,不管别人的文章写得有多好有多清晰多牛掰,始终不是我们自己的,也有可能存在 bug 。这也是我为什么建议大家看阅读量稍微高些的文章,因为有问题大家会评论提出来,会经过很多次的修正调整。我们最好自己亲身去实践,自己做做笔记或者写写文章,把它真正变成自己的知识,这样提升的速度是非常快的,屡试不爽。

    以下是一些源码分析的文章,我们可以选择性的挑一些啃一啃,如果文章看不太懂还可以看看直播视频:

    三.惯用套路


    每个人阅读源码的思路都会有些不一样,姿势也会有所不同,下面我仅代表个人的观点谈谈我的惯用套路,假如我们想去分析 glide 这个开源库,假设现在网上的资料也没法满足我们了:

    第一步会去画 UML 时序图,相信很多哥们在分析 glide 源码的时候,刚开始可能连访问网络的码头都找不到。画时序图不光能防止我们沉入茫茫大海,还能让整个加载显示流程都非常清晰,好记性不如画流程图。

    第二步会去画 UML 类图,每个第三方库在其架构设计上,都会有其值得借鉴的地方。如 retrofit 这个开源库,虽然类文件并不多,但里面的封装解耦思想,都能够在我们实际的开发过程中派上用场。

    第三步会去抓细节,比如 glide 怎么压缩适配图片的,缓存怎么处理的,是如何加载 gif 图片的,怎么解析视频封面的。我们在开发过程中遇到的很多问题,源码会给我们很多更好的解决方案。

    第四步会去参考模仿,并不是建议大家去重复造轮子,比如我们知道了 IOC 的实现原理,就能完美的解决 mvp 中多 prsenter 的情况;清楚了 RxPermission 的实现方式我们就能很轻松的写出类似 RxPay 和 RxShare 等等。

    第五步会去反思现有的架构设计,我们在写项目的时候,往往由于时间的原因,只是考虑了怎么实现,能实现能按时上线就好。随着业务的不断修改增加,可能已经没有了高蛋白低脂肪。当然随着经验的增长考虑的也会多一些,但仍然需要不断的反思和学习。

    四.随心所欲


    当我们阅读了大量的源码和第三方开源库后,我们就能打通任督二脉。这个时候当同事遇到一些棘手的 bug ,我们能从源码的角度去分析解决;一些难以实现的需求,我们也能很快的找到解决方案。这时我们要么是在大公司镀金,要么是在小公司做负责人,是真正的喜欢工作、学习和折腾。

    相关文章

      网友评论

      • 小县城公务员:你好!我们是程序员大咖旗下专注于程序员生态的公众号程序员大咖(微信号 CodePush)。我们很赞赏你的文章,希望能获得转载授权。授权后,你的文章将会在公众号程序员大咖、程序员共读、源码共读、Java编程精选、iOS开发等渠道发布。我们会注明来源和作者姓名。
        非常感谢~~~
      • plus彭于晏:想要进阶,都要跨过阅读源码这关吧
      • plus彭于晏:我现在有一个烦恼,就是做一个项目,不知道如何下手,比如说最近在搞一个音乐播放器,我不知道怎么下手,然后我就去Github找了一个 源码,下载下来,整个项目的源代码基本上都能看懂,但是自己 就是想不到,某个功能是用哪个类去做,这是因为自己敲代码敲得少的原因吗,我觉得也不算敲得少了吧,可能学习的方法不对,都不知道怎么办好了,多敲代码是主要,但我觉得除了这个,我其他方面改一下就挺好的,就是找不到哪里去改
        相互交流:@墨辰lyb 只是敲代码,不思考只是码工,最重要的是思想的改变,和平时的习惯,多尝试提取代码,建议多看看设计模式。思想改变,代码自然提升
      • 259c1c37b7cc:厉害了我的哥
      • Joseph_L:这两天没听课,才发现辉哥终于换电脑了:joy::joy:
      • MigrationUK:厉害厉害
      • SharryChoo:辉哥的总结很受用~🙏
      • 向前的zz:很强,谢谢😂
        向前的zz:@红橙Darren 您这篇文章是推送的,随便进来的,没怎么仔细看。睡觉去了,明天早上再仔细看看,安卓源码是红的没怎么在意,看这篇文章应该解决这个疑问,晚安。
        红橙Darren:@zhousaito 这么晚还没睡:joy:

      本文标题:Android进阶之旅 - 源码阅读的经验总结

      本文链接:https://www.haomeiwen.com/subject/rlycmftx.html