. : : Assembly Language : : .  |  首页  |  我提出的问题  |  我参与的问题  |  我的收藏  |  消息中心   |  游客  登录  | 
刷新 | 提问 | 未解决 | 已解决 | 精华区 | 搜索 |
  《汇编语言》论坛 ->寄存器(内存访问)
  管理员: assembly   [回复本贴] [收藏本贴] [管理本贴] [关闭窗口]
主题 : :  一个小发现  [待解决] 回复[ 3次 ]   点击[ 430次 ]  
arthur007
[帖 主]   [ 发表时间:2010-10-03 23:04 ]   [引用]   [回复]   [ top ] 
荣誉值:0
信誉值:0
注册日期:2010-10-03 11:16
首先从栈操作指令所完成的功能的角度上来看,push pop等指令在执行的时候只修改sp,所以栈顶的变化范围是0~ffffh.从栈空的时候sp=0 一直压栈,直到栈满sp=0,如果再次压栈,栈顶将环绕。
这是书中的原话
那么我想问的是:
当栈中只有一个元素是,sp=fffeh,唯一一个元素出栈是,则sp+2=0
那么若进栈一个字,则sp=sp-2=0-2=fffeh
感觉很奇怪,
望高手给予详细解答
vs9841
[第1楼]   [ 回复时间:2010-10-13 06:44 ]   [引用]   [回复]   [ top ] 
荣誉值:0
信誉值:0
注册日期:2009-01-17 12:29
CPU只是通过SS:SP来决定栈顶的位置。SS段地址固定不变,只是变化SP来变化确定栈顶的位置方向。那么变化空间就0000到FFFF。正如你的发现一样。当栈顶指向FFFE时,按你的假设,就会出现栈环绕现像。很正常。因为SS段地址不会自己去减去加。
arthur007
[第2楼]   [ 回复时间:2010-10-15 07:03 ]   [引用]   [回复]   [ top ] 
荣誉值:0
信誉值:0
注册日期:2010-10-03 11:16
有人回复的感觉真好
另外,我奇怪的是sp=0-2=fffeh
寄存器借1的问题
linfeng0928
[第3楼]   [ 回复时间:2011-01-19 12:35 ]   [引用]   [回复]   [ top ] 
荣誉值:0
信誉值:0
注册日期:2011-01-01 18:29
什么是栈环绕,难道是偏移地址覆盖。
需要登录后才能回帖 -->> 请单击此处登录
    Copyright © 2006-2024   ASMEDU.NET  All Rights Reserved