断点的本质-INT 3

《2》 int 3

  INT 3 是中断指令的一种特殊形式,仅有一个字节长。

  调试器将该指令当作软件中断指令来用。调试的时候,当程序中的某一位置加断点的时候,调试器会把断点处指令编码的第一个字节替换为INT 3指令的编码。

当程序执行到INT 3,回向调试器申请系统调用,调试器因此获得CPU控制权。之后,再用原先的编码替换INT 3 编码。

https://www.cnblogs.com/feng9exe/p/12520962.html

 

考虑一下调试器是如何设置断点的。当我们在调试器中对代码的某一行设置断点时,调试器会先把这里的本来指令的第一个字节保存起来,然后写入一条INT 3指令。因为INT 3指令的机器码为11001100b(0xCC),仅有一个字节,所以设置和取消断点时也只需要保存和恢复一个字节,这是设计这条指令时须考虑好的。

https://blog.csdn.net/trochiluses/article/details/20209593

posted @ 2021-02-02 19:38  zzfx  阅读(284)  评论(0编辑  收藏  举报