. : : Assembly Language : : .  |  首页  |  我提出的问题  |  我参与的问题  |  我的收藏  |  消息中心   |  游客  登录  | 
刷新 | 提问 | 未解决 | 已解决 | 精华区 | 搜索 |
  《汇编语言》论坛 ->第一个程序
  管理员: assembly   [回复本贴] [收藏本贴] [管理本贴] [关闭窗口]
主题 : :  关于压栈超界问题  [已解决] 回复[ 4次 ]   点击[ 227次 ]  
winsun
[帖 主]   [ 发表时间:2010-01-05 11:31 ]   [引用]   [回复]   [ top ] 
荣誉值:0
信誉值:0
注册日期:2010-01-04 16:08
书上讲到连续多次push ax之后,超出栈顶范围会覆盖栈外内存,可是我在写2000:0处写代码如下
mov ax, 1000
mov ss, ax      ;将1000的内存设为栈
mov sp, 6       ;设置栈顶
push ax         ;连续压入栈
push ax
push ax
push ax
push ax

然后再将cs指到2000,将ip指到0
开始用t命令单步执行,当第二次push ax之后debug就退出来了,这是不是因为栈顶已经超界而导致的?
scuzg
[第1楼]   [ 回复时间:2010-01-05 12:07 ]   [引用]   [回复]   [ top ] 
荣誉值:307
信誉值:0
注册日期:2009-03-15 23:46
我认为是这样的:当连续压栈导致数据存入1000:0fffeh、1000:0fffch等单元,导致和程序或系统的其他数据冲突。如果 sp 的初值大于 8 ,则不会出现这样的情况。
winsun
[第2楼]   [ 回复时间:2010-01-05 12:30 ]   [引用]   [回复]   [ top ] 
荣誉值:0
信誉值:0
注册日期:2010-01-04 16:08
谢谢您, 我照您的方法试试。
winsun
[第3楼]   [ 回复时间:2010-01-05 12:53 ]   [引用]   [回复]   [ top ] 
荣誉值:0
信誉值:0
注册日期:2010-01-04 16:08
回复:[第2楼]
------------------
说得有道理,我已经按您说的方法试了,结果是对的,果然是覆盖了栈顶以上的内存:
2FFF:0030  00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00   ................
2FFF:0040  00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00   ................
2FFF:0050  00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00   ................
2FFF:0060  00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00   ................
2FFF:0070  00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00   ................
-t

AX=0005  BX=0000  CX=0000  DX=0000  SP=0008  BP=0000  SI=0000  DI=0000
DS=0B38  ES=0B38  SS=3000  CS=2000  IP=001B   NV UP EI PL NZ NA PO NC
2000:001B 50            PUSH    AX
-t

AX=0005  BX=0000  CX=0000  DX=0000  SP=0006  BP=0000  SI=0000  DI=0000
DS=0B38  ES=0B38  SS=3000  CS=2000  IP=001C   NV UP EI PL NZ NA PO NC
2000:001C B80600        MOV     AX,0006
-d 2fff:0
2FFF:0000  00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00   ................
2FFF:0010  1C 00 00 20 9C 05 05 00-04 00 03 00 02 00 01 00   ... ............
2FFF:0020  00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00   ................
2FFF:0030  00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00   ................
2FFF:0040  00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00   ................
2FFF:0050  00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00   ................
2FFF:0060  00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00   ................
2FFF:0070  00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00   ................
-
winsun
[第4楼]   [ 回复时间:2010-01-05 13:17 ]   [引用]   [回复]   [ top ] 
荣誉值:0
信誉值:0
注册日期:2010-01-04 16:08
此贴由 贴主 于 [ 2010-01-05 13:17 ] 结贴。 结贴原因:问题已解决
得分情况:
此问题已结贴!
    Copyright © 2006-2024   ASMEDU.NET  All Rights Reserved