原本的标题的《定位程序代码的方法》,但问题有时候超出了自己代码的范围,而是别人的程序,所以今天想分享的是一个通用的分析问题(程序)的思路。
先来说一下在使用别人的程序(Vim)过程中遇到问题的一个例子。
某日,程序猿在Vim飞快地敲着键盘,突然在输入命令 :b 时软件没有响应,一直卡死。
程序猿A):直接Kill 了vim 这个进程,重新启动vim 算了。
程序猿B):我想知道它(vim程序)正在干嘛,这样我就知道它为什么卡了。
大部分人都是选择A,他们的理由是这不是主要的问题,工具可用(重启)就可以了,主要的工作还是在写自己的代码呀。人复一日,只低头看见自己那点代码,而没抬头见过世面,进步和觉悟可想而知了。
嗯,我们在聊聊B的思路。
我们需要借助 strace 工具来查看程序的运行状态,从下图可以看到 vim 一直在select 句柄 1(标准输入)等待用户的输入,知道这些,于是按下 Ctrl + C,vim 就不卡了。
在windows 和 OS X 、UNIX 下都有对应的工具,如sysintenals 套件、dtruct 等等。这些工具才能看到程序当前调用的API,打开的文件和端口 ...
大多数情况下,我们知道了程序调用的API就大概知道程序在干嘛了。
少数情况下我们需要才往下一点,动态调试程序的汇编指令,这个就不打算再深入了。