前几天在公司,突然和Dafan同学讨论起编译器是如何实现调试断点的,这下才突然意识到,每天编程在调试的时候都会去设断点,但从来没有思考过编译器或者操作系统式如何实现程序的调试断点的,于是我们 <script src="http://hi.images.youkuaiyun.com/js/blog/tiny_mce/themes/advanced/langs/zh.js" type="text/javascript"></script> <script src="http://hi.images.youkuaiyun.com/js/blog/tiny_mce/plugins/syntaxhl/langs/zh.js" type="text/javascript"></script> 展开了讨论。
首先,我们觉得,不大可能是在目标程序里插入了代码,因为这个断点我们可以随时设置或取消,如果是在生成程序或者在操作系统载入程序时插入了调试代码的话做不到这一点。
然后我们又否定了操作系统不可能动态的在进程里插入调试跳转命令,因为一个程序被操作系统载入内存以后,程序中的跳转命令的跳转地址就已经确定了,如果这时候操作系统再插入一些调试命令的话,那些跳转指令就会错了。
这时,我提出,或许操作系统提供了一些寄存器,里面存了调试断点的位置,这样操作系统在每执行一条命令(或者一组原子命令)以后就查看一下是否到了断点的地方,再确定是跳转到调试程序还是继续执行。