. : : 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