段与段不能重合使用!!!
下面这种做法很不安全,如果在程序中出现这种程序代码,将CS段地址直接赋值给SS段使用,有可能导致灾难性后果。因为在段初始化时,会将几个寄存器值放到段内,随着PUSH操作的进行,这些值将会向低地址方向作整体移动,此时会覆盖CS段内开始定义的8个字的数据。
assume cs:codesg
codesg segment
dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h
dw 0,0,0,0,0,0,0,0
start: mov ax,cs
mov ss,ax #将CS段地址直接赋给SS段
mov sp,30h
mov bx,0
mov cx,8
s: push cs:[bx]
add bx,2
loop s
mov bx,0
mov cx,8
s0: pop cs:[bx]
add bx,2
loop s0
mov ax,4c00h
int 21h
codesg ends
end start
程序运行前,内存状态:
第1次push操作后,内存状态: