关于检测题6.1第二题引发的疑问
本帖最后由 loop 于 2011-5-19 16:34 编辑就是我在做检测题6.1第二题的时候,程序没有错误,也debug调试了,发现程序中的数据确实被修改了,可是同时也发现了一个问题,就是为什么内存单元0:0~0:F这段内存的数据也被修改了啊,这样的话,那不是与原始的意愿相违背的么assume cs : code
code 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
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
code ends
end start程序执行前
d 0:0 f
0000:0000 68 10 A7 00 8B 01 70 00-16 00 A3 03 8B 01 70 00
当执行第一句指令后,内存单元里的数据就变了,成了下面的数据
d 0:0 f
0000:0000 68 10 A7 00 8B 13 E2 0D-16 00 A3 03 B1 13 E2 0D
这是什么原因啊,如果一开始就把0:0~0:F这段内存的数据修改了,那传送还有什么意义啊,不懂~~~~~~~~~~~~ 你是在纯 8086下调试得到的结论么?还是 虚拟模式,如果虚拟模式的话这种现象是正常的。
页:
[1]