tongpew 发表于 2012-7-30 09:34:35

求解!~

mov ax,1000
mov ds,ax
mov ax,2000
mov ss,ax
mov sp,10
push
psuh
psuh
push
push
push
push
psuh
执行到push ;就执行不了。
还有 最后的地址(20000H~20004H) 不知道是从那里跑出来的内容。 在没执行前 初始了
10000H~1000FH :00 11 22 33 44 55 66 77 88 99 AA BB CC DD EE FF
20000H~2000FH :00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
最后 在不执行 push 的情况下 查看了下 2000:0000
发现 结果出乎意料:5F 13 C3 OD AA BB 88 99 66 77 44 55 22 33 00 11;
郁闷啊!~
求解!

lukelqz 发表于 2012-7-30 09:34:36

本帖最后由 lukelqz 于 2012-7-30 14:14 编辑

{:5_94:}有什么出乎意料的,结果很正常啊。为什么到push 不能执行的原因是,你是不是用了debug里面的t命令,单步调试命令?这个命令每次执行的时候都会向栈空间写入临时数据,还有产生中断什么的。(网上说的啊。)所以导致你的栈空间不够用了。产生了栈顶越界的问题。所以出现了debug弹出错误的窗口。

最后 在不执行 push 的情况下 查看了下 2000:0000
发现 结果出乎意料:5F 13 C3 OD AA BB 88 99 66 77 44 55 22 33 00 11
这个完全正确啊。你总共执行了6次push。把10000H~1000BH :00 11 22 33 44 55 66 77 88 99 AA BB 这些数据压入了栈空间。首先你要知道栈是从高地址往低地址压入的,也就是每次执行push后系统自动sp=sp-2,并且是以字为单位,就是一次要压入两个字节。
{:5_91:}字有点丑

Potato丶 发表于 2012-7-30 18:34:15

- -如楼上所说,就是一点没Push。栈中也有数据的。。
记得貌似是CS。IP和标志寄存器中的值首先压入栈中。
执行不了的话是越界了或者改写的别的程序正在使用的内存。产生错误。
页: [1]
查看完整版本: 求解!~