汇编语言监测点6.1第二题的问题
我的程序是这样的:assume cs:code
code segment
dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h
dw 0
start:mov ax,cs
mov ss,ax
mov sp,12h
mov ax,0
mov ds,ax
mov bx,0
mov cx,8
s:push
pop cs:
add bx,2
loop s
mov ax,4c00h
int 21h
code ends
end start
---------------------------
我的想法是,因为push一下,又pop一下,那么堆栈不是只要一个字节的空间就够吗?
所以定义dw 0
然而我错了,不知道错在哪里?
debug一下
-d 0:0 f
-d cs:0 f
发现两处没有完全对上。
而如果我将dw 0改为dw 0,0,0,0,0,0,0,0,
mov sp ,12h改为mov sp ,20h
再debug查看下
-d 0:0 f
-d cs:0 f
两处的数据一样了。
总而言之,对于ss区到底要开辟多少,我现在完全没有注意,
愚昧的我,请大家赐教。
本帖最后由 Potato丶 于 2012-7-17 23:22 编辑
{:5_109:}哦。明白了。照你那么写试了一下
的确会出现这种结果。然后我记得以前说过这个问题。
下面看实验2书上有一段是这样的:
仔细看这段程序。发现还没往栈里写东西。栈的值就改变了。
又参看了甲鱼的解释:
- -姑且就是这样。
你那样写确实越界了。你看看是不是没对上的值被标志寄存器,CS段寄存器,IP的值覆盖了?
所以- -尽量多开辟点栈空间。不要正合适。
本帖最后由 Potato丶 于 2012-7-17 22:38 编辑
{:5_99:}当我没说。。。我也正在学。等会再看看。。
Potato丶 发表于 2012-7-17 21:50 static/image/common/back.gif
栈是以字型为基础的。一个字节怎么行。PUSH一下SP就要减2。。你一个字节显然越界- -
dw不是定义一个字型ma ?
dw 0也是占一个字吧?? :D
嗯。知道了。
ths 终于明白了。谢谢。
页:
[1]