kithon 发表于 2011-4-26 09:19:24

程序6.3的一些疑问

本帖最后由 loop 于 2011-4-27 03:29 编辑

hello guys,
今天看到王爽汇编程序6.3,我debug了一遍,中间出现了一点小小的问题,百思不得其解,不知道各位是否有知道的。
程序如下:assume cs:codesg //程序的作用是将8个数据入栈
          codesg segment
          dw 0123h, 0456h, 0789h, 0abch, 0defh, 0fedh, 0cbah, 0987h
          dw 0, 0,0,0,0,0,0, 0,0,0,0,0,0,0,0,0
            mov ax, cs
            mov ss, ax
            mov sp, 30h       -->当执行这句的时候原本数据都为0 的栈内,无缘无故多了几个数据
            mov bx, 0
            mov cx, 8
      s:push cs:
            add bx, 2
            loop s

141D:0032 8ED0          MOV   SS,AX
-d 141d:0 2f
141D:000023 01 56 04 89 07 BC 0A-EF 0D ED 0F BA 0C 87 09
141D:001000 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00
141D:002000 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00   ->未执行 mov sp, 30h
-t

AX=141DBX=0000CX=0058DX=0000SP=0030BP=0000SI=0000DI=0000
DS=140DES=140DSS=141DCS=141DIP=0037   NV UP EI PL NZ NA PO NC
141D:0037 BB0000      MOV   BX,0000
-d 141d:0 2f
141D:000023 01 56 04 89 07 BC 0A-EF 0D ED 0F BA 0C 87 09
141D:001000 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00
141D:002000 00 00 00 00 00 1D 14-00 00 37 00 1D 14 15 0E   ->执行 mov sp, 30h后,多出这些数据
继续执行push 0123H后
-d 141d:0 2f
141D:000023 01 56 04 89 07 BC 0A-EF 0D ED 0F BA 0C 87 09
141D:001000 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00
141D:002000 00 00 00 1D 14-00 00 37 00 1D 14 15 0E 23 01 -->0123H入栈后,多余的数据都同时向前移动
在朋友机器上调试也会出现这种问题,只是多余的那些数据稍稍变了一下
如果改为mov sp, 20h;在push的过程中这些数据就会占领cs:0~cs:f 中的数据,有危险。
问题:这几个数据是从何而来,它们的作用又是什么呢?
希望知道的童鞋能不吝赐教~

yilan1314 发表于 2011-4-26 09:29:47

注意你用的是CS段地址而不是重新定义,当你执行MOV BX,0000的时候CS:IP会执行相关机器码。不知道这样说你是否懂.

kithon 发表于 2011-4-26 10:01:42

回复 yilan1314 的帖子

有点迷糊~呵呵~
不过 mov sp,30h之后那些数据就出现了
这时候mov bx,0还没有执行
而且在不同的机器上,显示的数据也不同
应该不是某段代码的16进制表示

winddyj 发表于 2011-4-26 10:31:07

DEBUG等调试工具产生的数据,无视就好
因为调试用到中断,中断的调用与返回就像CALL一样,需要压栈取栈

kithon 发表于 2011-4-26 19:01:57

回复 winddyj 的帖子

触发断点需要调用中断,中断的调用过程需要使用栈空间……
这个解释应该很靠谱, 先谢谢了:handshake
页: [1]
查看完整版本: 程序6.3的一些疑问