人造人 发表于 2015-12-18 20:55:32

关于mov sp,20h

assume cs:code,ds:data,ss:stack

data segment
                dw 0123H,0456H,0789H,0abcH,0defH,0fedH,0cbaH,0987H
data ends

stack segment
                dw 0,0,0,0,0,0,0,0
stack ends


code segment
start:      mov ax,stack
                mov ss,ax
                mov sp,20H
               
                mov ax,data
                mov ds,ax
               
                mov bx,0
               
                mov cx,8
      s:      push
                add bx,2
                loop s
               
                mov bx,0
               
                mov cx,8
      s0:      pop
                add bx,2
                loop s0
               
                mov ax,4c00H
                int 21H

code ends
end start
问题就在
mov sp,20H
该成
mov sp, 10h
也行
mov sp, 30h
也行
不清楚为什么20h就不行
这是一位朋友的问题
http://bbs.fishc.com/thread-67212-1-1.html
为什么啊?
求解?
先谢谢各位了

哈萝莉 发表于 2015-12-19 12:37:18

20h也行啊

聆云 发表于 2016-2-20 22:26:16

我们暂不考虑psp,来分析程序加载入内存的情况:内存中,最开始的0~15单元中,是定义的数据,也就是data中的数据,接下来的16~31单元中,是初始化的栈空间,大小是16个字节,栈顶就是10f(注意,数据断ds和栈断ss是不一样的,所以栈的指针要和数据断的指针分开。所以说,你把栈指针设为20h,你的栈顶就已经指到你代码段中去了,你再push 入站,实际上就把你的程序代码覆盖了,你程序自己把自己给吃了,不是么?而至于30h,恰好指到了你代码段的后面去了,这时候,push的内容不多,你运气好,就没改写到代码,如果push的数据过多,一样会改写了后排自前的代码

人造人 发表于 2016-2-20 22:42:11

聆云 发表于 2016-2-20 22:26
我们暂不考虑psp,来分析程序加载入内存的情况:内存中,最开始的0~15单元中,是定义的数据,也就是data中 ...

此问题已经解决了,谢谢你的回答

聆云 发表于 2016-2-20 22:44:58

(ˊωˋ*)
页: [1]
查看完整版本: 关于mov sp,20h