`_王爷 发表于 2012-4-23 11:19:04

早上用debug调试push这个指令的时候,遇到一个很困扰我的问题,求解。

早上用debug调试push这个指令的时候,遇到一个很困扰我的问题,求解。
首先就是我-d 2000:0 f 然后显示的是 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 意思就是空呗 。
好了,我开始我的下一步工作就是,-a
mov ax,2000
mov ss,ax
mov sp,0010
mov ax,8866
push ax
然后就开始调试完这些指令,
然后我再去-d 2000:0 f 然后就显示的是
00 00 00 00 66 88 00 00 0c f0 13 54 0e 66 88
我知道压是压进去了,但是我想知道的是那些本来是空的数,可是现在为什么是这些值,那些前面的数值是从哪儿来的?而且第五和第六个字节又是66 88,这个和上面的指令有什么必然的联系么?

`_王爷 发表于 2012-4-23 11:33:35

lazioprocn2000 发表于 2012-4-23 11:28 static/image/common/back.gif
他死,我记得。他生,我心动到惶然。

天公有大 美而无言

什么情况 ?

梦想与现实 发表于 2012-4-23 16:24:15

mov sp,0010
你这里应该写成 mov sp,10h
masm 默认的是十六进制的,你如果写成0010 编译器会认为这个是十进制的,所以编译链接的时候会改变为
十六进制,这样你的栈底指针就不是你想要的了!

`_王爷 发表于 2012-4-24 10:24:41

梦想与现实 发表于 2012-4-23 16:24 static/image/common/back.gif
mov sp,0010
你这里应该写成 mov sp,10h
masm 默认的是十六进制的,你如果写成0010 编译器会认为这个是十 ...

但是这个代码是我直接在debug上调的 , 没用masm编译和连接的啊 。
页: [1]
查看完整版本: 早上用debug调试push这个指令的时候,遇到一个很困扰我的问题,求解。