相遇♂不离 发表于 2011-4-19 16:16:29

关于检测题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这段内存的数据修改了,那传送还有什么意义啊,不懂~~~~~~~~~~~~

china0008 发表于 2011-5-3 11:09:51

你是在纯 8086下调试得到的结论么?还是 虚拟模式,如果虚拟模式的话这种现象是正常的。
页: [1]
查看完整版本: 关于检测题6.1第二题引发的疑问