|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
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 [bx]
add bx,2
loop s
mov bx,0
mov cx,8
s0: pop [bx]
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
为什么啊?
求解?
先谢谢各位了
我们暂不考虑psp,来分析程序加载入内存的情况:内存中,最开始的0~15单元中,是定义的数据,也就是data中的数据,接下来的16~31单元中,是初始化的栈空间,大小是16个字节,栈顶就是10f(注意,数据断ds和栈断ss是不一样的,所以栈的指针要和数据断的指针分开。所以说,你把栈指针设为20h,你的栈顶就已经指到你代码段中去了,你再push 入站,实际上就把你的程序代码覆盖了,你程序自己把自己给吃了,不是么?而至于30h,恰好指到了你代码段的后面去了,这时候,push的内容不多,你运气好,就没改写到代码,如果push的数据过多,一样会改写了后排自前的代码
|
|