徐缘 发表于 2011-10-3 19:25:57

为什么明明是1ah,怎么会变成24h了,监测点6.1--详细解答-《汇编语言》-课后题

assume cs:codesg
codesg 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

cathe 发表于 2011-10-3 20:38:46

确实是 1ah

老头子学汇编 发表于 2011-10-4 00:27:42

本帖最后由 老头子学汇编 于 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

topcookie 发表于 2011-10-4 20:53:42

定义的是36字节数据,当然SP指向36,也就是24H了,自己多看看书上栈的那一节,尤其是栈为空时SP指向哪里
页: [1]
查看完整版本: 为什么明明是1ah,怎么会变成24h了,监测点6.1--详细解答-《汇编语言》-课后题