关于进栈和处栈顺序的问题
该问题是实验10第3问显示数值的问题这里有两个差不多一样的代码,就是子程序dtoc进栈和处栈顺序不一样的问题,如下:
(1)
assume cs: code
data segment
db 10 dup (0)
data ends
code segment
start : mov ax, 12666
mov bx, data
mov ds, bx
mov si, 0
call dtoc
mov dh, 8
mov dl, 3
mov cl, 2
call show_str
mov ax, 4c00H
int 21H
dtoc :push ax
push bx
push cx
push dx
push si
push di
mov di, 0
d10 : mov dx, 0
mov bx, 10
div bx
add dx, 30H
push dx
inc di
mov cx, ax
jcxz d11
jmp d10
d11: mov cx, di
d12: pop dx
mov , dl
inc si
loop d12
mov dl, 0
mov , dl
okay: pop si
pop di
pop dx
pop cx
pop bx
pop ax
ret
show_str:mov bx, 0
mov ax, 0b800H
mov es, ax
dec dh
mov al, dh
mov dh, 160
mul dh
mov bx, ax
mov al, dl
mov dl, 2
mul dl
add bx, ax
mov ah, cl
mov cl, 0
show :mov al,
mov es:, ax
mov ch,
inc si
add bx, 2
jcxz ok
jmp show
ok : ret
code ends
end start
(2)
assume cs: code
data segment
db 10 dup (0)
data ends
code segment
start : mov ax, 12666
mov bx, data
mov ds, bx
mov si, 0
call dtoc
mov dh, 8
mov dl, 3
mov cl, 2
call show_str
mov ax, 4c00H
int 21H
dtoc :push ax
push bx
push cx
push dx
push si
push di
mov di, 0
d10 : mov dx, 0
mov bx, 10
div bx
add dx, 30H
push dx
inc di
mov cx, ax
jcxz d11
jmp d10
d11: mov cx, di
d12: pop dx
mov , dl
inc si
loop d12
mov dl, 0
mov , dl
okay: pop ax
pop bx
pop cx
pop dx
pop si
pop di
ret
show_str:mov bx, 0
mov ax, 0b800H
mov es, ax
dec dh
mov al, dh
mov dh, 160
mul dh
mov bx, ax
mov al, dl
mov dl, 2
mul dl
add bx, ax
mov ah, cl
mov cl, 0
show :mov al,
mov es:, ax
mov ch,
inc si
add bx, 2
jcxz ok
jmp show
ok : ret
code ends
end start
这两个代码就是因为进入栈的顺序不一样就能导致得到不同的结果,前者能够显示想要的结果,而后者却是乱码,这是为什么呢?(用的masm5.0编译) 先说一下FILO:first in last out,先进后出,要是先进的直接pop给先进的寄存器,那你寄存器得到的数据就和一开始你想要的不一样了。
再来看你的程序,虽然你pop出来的几个寄存器的值在显示代码段感觉用不上都是要被重新定义的,但是你忽略了一个si,你在显示代码段里没重新赋值0,所以一直用start代码段里的si,第二个程序你的si已经填入了bx的值,就不会是0了。所以得到的是什么谁知道那。再来说你第一个程序,你的pop也出错了,先pop di,再pop si。
如果还有不明白的点“回复”追问哦。 丶忘却的年少o 发表于 2017-9-19 10:39
先说一下FILO:first in last out,先进后出,要是先进的直接pop给先进的寄存器,那你寄存器得到的数据就和 ...
第二个程序并没有将bx的值赋给si啊
你还是没说清楚为什么pop的顺序不一样,得到的结果就不一样 若余相思 发表于 2017-9-19 10:57
第二个程序并没有将bx的值赋给si啊
你还是没说清楚为什么pop的顺序不一样,得到的结果就不一样
假设ax,bx,cx,dx,si,di分别是1,2,3,4,5,6,按照你第二个顺序取出来ax,bx,cx,dx,si,di的值就变成了6,5,4,3,2,1
从栈顶一个一个存放进去,然后从存放的最后一个数的地址反向取出。虽然你没直接mov si, bx,但是你pop si的值就是push bx进去的值。
页:
[1]