灰色记忆 发表于 2012-5-14 12:15:41

一个很纠结的问题,就回答?

assume cs:code
code 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 sp,32h
         mov bx,0
         mov cx,8
s:      push cs:
      addbx,2
      loops
         mov bx,0
         mov cx,8
s0:   pop cs:
      add bx,2
      loop s0
         mov ax,4c00h
         int 21h
code ends
end start   
这是书本上的一段例题,我用debug调试后,入栈数据怎么不和出栈数据一样,是什么原因?                                    
入栈数据:0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h
出栈数据:0987h,0cbah,0fedh,0defh,下面的数据就和入栈的数据就不一样了

Yara 发表于 2012-5-14 12:20:47

看来你还不了解栈的意义,入栈和出栈是FILO,意思是先进后出,就是数据先进去的是后面出来的

离尘※影 发表于 2012-5-14 12:55:33

mov sp,32h
定义了50个字节的栈空间应该会覆盖掉下面的指令吧?

Yara 发表于 2012-5-14 13:38:34

离尘※影 发表于 2012-5-14 12:55 static/image/common/back.gif
mov sp,32h
定义了50个字节的栈空间应该会覆盖掉下面的指令吧?

这里的mov sp,32是把栈顶指向CS:32,当push cs:时,sp会先减2,再把cs:的值推进栈里(即此时(cs:30)=0123h)

霸王龙 发表于 2012-5-14 18:58:40

定义的栈段不够长咯

侮辱后的坚强 发表于 2012-5-14 19:34:06

应该是是 mov sp,24h吧;是16个字 32个字节32用16进制是24H

Seely 发表于 2012-5-14 21:27:43

不知道你是抄错了还是故意不按书上来的,总之你的代码有问题。
dw 0,0,0,0,0,0,0,0
如果你是想把这些 0 当栈段的话,你少定义了8个字。
mov sp,32h
由于上面的错误,你这里指定的栈顶已经超出了你定义数据的地方,到放代码的地方了。

玩酷子弟lv 发表于 2012-5-14 21:46:57

把mov sp,32h,换成mov sp,20h就可以了

侮辱后的坚强 发表于 2012-5-15 11:13:46

mov sp,32h    换为 mov sp,32 或 mov sp,24H 原因 我一解释过

灰色记忆 发表于 2012-5-20 00:15:01

经过各位鱼友的回答,让我对栈有了更深的理解 。在这里先谢谢各位了。。。

刺客信条 发表于 2013-6-7 17:32:14

定义的栈段不够长
页: [1]
查看完整版本: 一个很纠结的问题,就回答?