程序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 中的数据,有危险。
问题:这几个数据是从何而来,它们的作用又是什么呢?
希望知道的童鞋能不吝赐教~ 注意你用的是CS段地址而不是重新定义,当你执行MOV BX,0000的时候CS:IP会执行相关机器码。不知道这样说你是否懂. 回复 yilan1314 的帖子
有点迷糊~呵呵~
不过 mov sp,30h之后那些数据就出现了
这时候mov bx,0还没有执行
而且在不同的机器上,显示的数据也不同
应该不是某段代码的16进制表示 DEBUG等调试工具产生的数据,无视就好
因为调试用到中断,中断的调用与返回就像CALL一样,需要压栈取栈 回复 winddyj 的帖子
触发断点需要调用中断,中断的调用过程需要使用栈空间……
这个解释应该很靠谱, 先谢谢了:handshake
页:
[1]