代码如下:
A. 从下面一幅图看出,CALL指令要转到地址是:0013,位移是:E80500,读作:00 05,下一条指令偏移地址是:0E(076B:000E偏移地址取低位8字节),十六进制相加:05 + 0E = 0013。
B. 用指令:g 000B 直接执行到 076B:000B处,可以看到IP变成了 000B
C. 执行CALL会把IP压栈,即把call下一条指令的偏移地址压栈,从图中可以看出,未执行call指定前,地址最后2位是一个随机数 01 A3,执行压栈后,最后2位是 00 0E。
D. 执行ret指令后,IP偏移地址又变回了00 0E,接着执行下一条指令 mov ax,4c00,如图:
汇编语言-call和ret指令设置栈详解
最新推荐文章于 2024-06-14 00:14:46 发布