冷漠的滋味 发表于 2013-7-27 17:49:50

第六章程序6.3的问题


file:///C:/Documents%20and%20Settings/Administrator/Application%20Data/Tencent/Users/1520124924/QQ/WinTemp/RichOle/C1~TWHI7MV8G81~6D$Q0LFM.jpg源码:                                                                  
assume cs:shiyan
shiyan segment
dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h
dw 0,0,0,0,0,0,0,0

start: mov ax,cs
mov ss,ax
mov ds,ax
mov sp,20h

mov bx,0
mov cx,8
s:push
add bx,2h
loop s

mov bx,0
mov cx,8
a:pop
add bx,2
loop a

shiyan ends
end start

Dardy 发表于 2013-7-27 17:49:51

单步执行,每次都需要保护现场,一些寄存器的值会入栈。
mov sp,20h 栈初始化后,下句mov bx,0运行,你就可以看到栈里面压入了一些值,而这些值并非自已的代码压入的。
栈空间不够大,一次运行完和单步执行的结果会不一样。

福禄娃娃 发表于 2013-7-28 09:21:01

emu8086中的运行结果和debug中的不一样,他们的处理机制应该不同,emu8086不会出现以上现象。
因为debug和masm编译器对指令的不同处理造成的
push 需要显示的给出寄存器 push cs:
debug 中处理 为内存地址
masm中处理为立即数
1415:0010中的内容1415入栈覆盖了0987
楼主应该使用一个堆栈段专门存储堆栈信息。

冷漠的滋味 发表于 2013-7-28 21:48:44

懂了,谢谢大家

页: [1]
查看完整版本: 第六章程序6.3的问题