无名侠 发表于 2014-1-19 20:56:56

【探究】当SS和SP的值都为0时入栈然后弹出 为什么值没有变化--请看我的分析!

首先打开你的Debug。
让我们用神奇的A命令敲入一下代码
mov ax,0
mov ss,ax
mov sp,0
mov ax,2014
push ax
xor ax,ax ;清空AX 不习惯的话 你可以用 mov ax,0 或者是 sub AX,AX子类的!
;现在你可以用d 0:0 10命令查看一下, 没有一点关于2014的值
pop ax ;好了,执行玩这一步,你看看AX的值,是不是又回来了?
压栈的数据到那里去了?被吞了?那为什么可以还原?
首先:
压栈的数据在内存的最顶端。
大家不妨用 D fff:0 10 来查看,找到了2014数据吗?呵呵,这里有很多压栈数据,比如:中断保存的CS和IP,标志寄存器之类的!

具体原理不妨去看看这个帖子(2楼回复的内容):
问一个关于单步中断压栈的问题
http://bbs.fishc.com/thread-42984-1-1.html


页: [1]
查看完整版本: 【探究】当SS和SP的值都为0时入栈然后弹出 为什么值没有变化--请看我的分析!