Debug是非常个性化的工作,但是有效的debug方法,解决问题的思路毫无疑问是建立在对系统,应用的理解上。
程序从编码到运行,有语法/编译问题,以及运行的问题。本系列的读书笔记主要讨论运行过程中遇到问题,如何继续调试。
从代码到完成,经历的阶段有:需求定义,设计,编码,测试,调试等。
- 编码:对项目进行编译与构建,修改并消灭编译错误与构建错误;
- 测试:发现bug,找出不符合预期的行为。有方法认为编写程序前先写测试程序,TDD,即测试驱动开发。
- 调试:对于给定的输入,确定输出是否符合预期。
调试的工具/方法,主要包括如下:
- 内核转储;
- GDB工具;
- 对于CPU架构,内存模型,参数传递的理解;
- 对于汇编语言的理解,反汇编查阅代码;
- Oops信息解读;
- SysRq键调试;
- strace,crash等命令;
- 内核调试相关的kernel panic;
- objdump的选项;
- Valgrind的使用;
- kprobes/jprobes/kprobes获取任意位置信息;
- systemtap进行调试;
- /proc/meminfo, 以及 /proc//mem 信息的解读;
- init节的理解。
个人认为,debug的过程,本身就是还原对代码/系统机制等理解,对于不符合预期的行为进行分析。
没有任何一个debug方法可以包罗万象,如果有,那么这个方法就是将所有计算机相关技术串在一起的指引,这样的指引,就是一个个不同的领域的知识的有机结合。
本系列将针对不同的主题,逐个进行实例记录,有基本的认识后,便于在对应的场合能使用合适的工具。