为什么明明是1ah,怎么会变成24h了,监测点6.1--详细解答-《汇编语言》-课后题
assume cs:codesgcodesg segment
dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h
dw 0,0,0,0,0,0,0,0,0,0
start:
mov ax,cs ;cs为所填第一空
mov ss,ax
mov sp,24h ;此条指令为所填第二空
mov ax,0
mov ds,ax
mov bx,0
mov cx,8
s:
push
pop cs: ;此条指令为所填第三空
add bx,2
loop s
mov ax,4c00h
int 21h
codesg ends
end start
小甲鱼详细分析:第一空,首先我们的“栈段”是定义在codesg segment代码段中的,所以我们ss的地址跟cs是一样的。第二空,因为前边已经定义了8个字型数据,所以我们的栈空间是从数据段后开始的,所以栈空间偏移地址为10到19,所以我们的栈顶指针指向1a(即栈底的下一个元素)。第三空,通过栈推出放回指定的空间。
本文来自:鱼C工作室<a href=http://www.fishc.com>详细出处参考:http://www.fishc.com/a/kehouti/_huibianyuyan_/839.html 确实是 1ah 本帖最后由 老头子学汇编 于 2011-10-4 01:34 编辑
ss=cs=codesg
内存地址
ss:0000 01 23 04 56 07 89 0a bc-0d ef 0f ed 0c ba 09 87
ss:0010 00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00
ss:0020 00 00 00 00 00
↑↑
23h-24H
dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h ;16字节
dw 0,0,0,0,0,0,0,0,0,0 ;注意dw十个0:10*2=20个字节
栈的空间是偏移10h~23h,栈顶指针24h(栈底的下一个元素)
16+20=36=24h
定义的是36字节数据,当然SP指向36,也就是24H了,自己多看看书上栈的那一节,尤其是栈为空时SP指向哪里
页:
[1]