尽可能全面的了解源码实现的功能有哪些
这样不会太容易变得大海捞针一般,而且容易梳理出比较核心的逻辑先去看。
善用调试技巧
猜测法
- 当看到某个方法时:猜测作者怎么实现的
- 当看到某个 类名|包名 符合某种设计模式时,猜测怎么使用这种设计模式实现的
如果一样会感到开心
如果不一样会感到好奇
整个过程就会很投入
下面几个都属于菜单栏 Navigate 下的
- 查看类的父类和子类结构 (会无视接口)
- 选择当前类名
-
按下快捷键Ctrl+H
若快捷键失效,查看菜单 Navigate - Type Hierarchy的快捷键
- 仅仅查看类子类列表(不是树状结构形式)
选中类名 Ctrl+Alt+B或option+command+B
具体的快捷键看菜单 Navigate-implementation的快捷键
- 查看类中所有定义的方法
Mac:Fn+Command+F12
Win:Ctrl + F12
具体的快捷键看菜单 Navigate -> File Structure 的快捷键
- 查看类或方法或变量的 所有 各种使用的地方
选中类名、方法名、变量名... 按下 Alt+F7或option+F7
展示当前类的类结构
在设置里面的keyamp搜索Structure
Mac:Command+7
Win:Alt+7
全局搜索代码内容
具体快捷键在Edit-Find-Find in Path菜单
全局搜索文件名
选择 文件名字符串 (比如 aaa.java文件,那么选择任何地方的aaa字符串都可以,也可以选择文件名的一部分),连按两下shift
注释要看,但要带着证实的心情看
大多情况下注释是正确的,但有些不好的代码。注释混乱
查看可运行安卓源码的xml布局
android studio的Layout Inspector工具可以将手机当前页面的布局树展示出来。里面有具体的xml属性
做好笔记
把看到过的东西,做好笔记。更容易看出关联。
比如整理UML图:类图、包图、序列图,等。
常见自问
- 1. 当调用b方法时就会导致控制台打印出 123
fun b(A a){
a.m()
}
-----------------
class A{
fun m(){
Log("123")
}
}
结论错误原因:传入的可能是A的子类,而且重写了m方法
方法:通过 断点 或 打印class名 确定当前传入的具体对象
-
2. 这里是不是核心流程
因为代码经常需要有一些额外的处理,当逐行看某个方法的实现原理的时候。容易跳到额外处理(库或功能模块)的方法上去。所以需要判断是不是核心流程,还是说只是核心流程的一些额外处理。
不过有时也要注意这个额外流程是否改变核心流程逻辑 (有些不怎么好的代码的单一原则控制的很差)。 -
3. 子类的思考
在看到任何地方代码的类的时候,要把该对象和其所有子类时的情况考虑进去。毕竟不一定就是传的这个类型。在面向对象语言里面很多时候传的是各种各样的子类 -
4.找不到后续流程
- 通过中间件(广播,线程通信,进程通信手段)继续后续流程
- 通过异步方式继续后续流程,比如 Future 模式、Promises 模式
- 通过回调方式继续后续流程
- 通过代理委托方式继续后续流程,比如动态代理
- ...
- 5. 非项目代码中的方法调用没调用不能只看项目中的代码,还要看第三方库和一些依赖包没有没调用。最好的是在方法上打断点通过断点溯源。
- 6.