三田学校 发表于 2012-7-17 00:22:39

汇编语言监测点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 00:22:40

本帖最后由 Potato丶 于 2012-7-17 23:22 编辑

{:5_109:}哦。明白了。照你那么写试了一下


的确会出现这种结果。然后我记得以前说过这个问题。

下面看实验2书上有一段是这样的:

仔细看这段程序。发现还没往栈里写东西。栈的值就改变了。
又参看了甲鱼的解释:
- -姑且就是这样。
你那样写确实越界了。你看看是不是没对上的值被标志寄存器,CS段寄存器,IP的值覆盖了?

所以- -尽量多开辟点栈空间。不要正合适。


Potato丶 发表于 2012-7-17 21:50:05

本帖最后由 Potato丶 于 2012-7-17 22:38 编辑

{:5_99:}当我没说。。。我也正在学。等会再看看。。

三田学校 发表于 2012-7-17 22:21:44

Potato丶 发表于 2012-7-17 21:50 static/image/common/back.gif
栈是以字型为基础的。一个字节怎么行。PUSH一下SP就要减2。。你一个字节显然越界- -

dw不是定义一个字型ma ?
dw 0也是占一个字吧??

三田学校 发表于 2012-7-21 21:27:43

:D
嗯。知道了。
ths

三田学校 发表于 2012-7-21 21:31:57

终于明白了。谢谢。
页: [1]
查看完整版本: 汇编语言监测点6.1第二题的问题