你的图片已经上传!
好好学习天天向上!
真是不好意思.
ESP=1FFEH ,才对!
真是不好意思了.
ax,bx,cx,这些是16位的汇编寄存器.
EAX,EBX,ECX,是32位的汇编寄存器.我把ax,bx,cx,.这些当成EAX,EBX.了,汇编来计算时所有入栈、出栈都是加的4.所以才错了.
它们入栈、出栈的占用空间的大小是不一样的.
16位的汇编是2字节,32位的是4字节所以搞错.
把图中的加、减4换成加减2就对了.
当成32位的汇编了,push 一次.ESP-4
在16位汇编中:
push axsp-2;记住入栈-2,也就是分配16位,2个字节的空间,用来存放ax
push bxsp-4
push cxsp-6
popaxsp-6+2ax=5566H; 出栈一次,腾出2字节16位的空间,还给系统,系统回收.
popcxsp-6+4cx=3344H
sp=1FFCH
2字节=(16位)/(8位/1字节),即每8位为一个字节
正如注释的那样
ax 是16的寄存器,所以sp-2或+2.EAX是32的寄存器,那么ESP-4或ESP+4