鱼C论坛

 找回密码
 立即注册
查看: 1990|回复: 3

第六章程序6.3的问题

[复制链接]
发表于 2013-7-27 17:49:50 | 显示全部楼层 |阅读模式
5鱼币
QQ图片20130727174852.jpg
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 [bx]
  add bx,2h
  loop s

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

shiyan ends
end start

最佳答案

查看完整内容

单步执行,每次都需要保护现场,一些寄存器的值会入栈。 mov sp,20h 栈初始化后,下句mov bx,0运行,你就可以看到栈里面压入了一些值,而这些值并非自已的代码压入的。 栈空间不够大,一次运行完和单步执行的结果会不一样。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2013-7-27 17:49:51 | 显示全部楼层
单步执行,每次都需要保护现场,一些寄存器的值会入栈。
mov sp,20h 栈初始化后,下句mov bx,0运行,你就可以看到栈里面压入了一些值,而这些值并非自已的代码压入的。
栈空间不够大,一次运行完和单步执行的结果会不一样。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2013-7-28 09:21:01 | 显示全部楼层
emu8086中的运行结果和debug中的不一样,他们的处理机制应该不同,emu8086不会出现以上现象。
因为debug和masm编译器对指令的不同处理造成的
push [bx] 需要显示的给出寄存器 push cs:[bx]
debug 中处理 [0] 为内存地址
masm中处理[0]为立即数
1415:0010中的内容1415入栈覆盖了0987
楼主应该使用一个堆栈段专门存储堆栈信息。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2013-7-28 21:48:44 | 显示全部楼层
懂了,谢谢大家

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-9-29 07:30

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表