GarfieldA 发表于 2019-2-21 15:52:34

第五章p26课的一个问题很迷惑

我用DOS Box单步调试的时候



mov al,ds:   


mov bl,ds:



就比如说这两步吧    我的跟小甲鱼视频上大不一样
我下边手打一下我不知道怎么添加图片的我的好像不能添加

在debug中单步调试

-t
AX=2000   BX=0000   CX=0019   DX=0000   SP=0000   BP=0000   SI=0000   DI=0000
DS=2000    ES=0770   SS=077F    CS=0780IP=0005    NV UP EI PL NZ NA PO NC
0780:0005 A00000            MOV       AL,                        DS:0000=53


-t

AX=2053   BX=0000   CX=0019   DX=0000   SP=0000   BP=0000   SI=0000   DI=0000
DS=2000    ES=0770   SS=077F    CS=0780IP=0008    NV UP EI PL NZ NA PO NC
0780:0005 A00000            MOV       BL,                        DS:0001=9A



问题就在于两个mov最后边的ds:0001和ds:0001等于的值小甲鱼的都是DS:0000=00

而我的为什么都是539A


我用d命令查看也不是全部是00   全部都是类似于9A的



jackz007 发表于 2019-2-21 15:58:04

   楼主,你在说什么,想办法让我们听明白。

GarfieldA 发表于 2019-2-21 15:59:10

jackz007 发表于 2019-2-21 15:58
楼主,你在说什么,想办法让我们听明白。

上传不了图片我只能手打出来了

jackz007 发表于 2019-2-21 16:00:22

本帖最后由 jackz007 于 2019-2-21 16:02 编辑

GarfieldA 发表于 2019-2-21 15:59
上传不了图片我只能手打出来了

    解决问题的第一步,你应该让别人能再现你遇到的问题。

    你用 debug 在干什么,是调试一个程序,还是键入一段代码再跟踪?把来龙去脉交代清楚。

GarfieldA 发表于 2019-2-21 16:27:10

jackz007 发表于 2019-2-21 16:00
解决问题的第一步,你应该让别人能再现你遇到的问题。

    你用 debug 在干什么,是调试一个程 ...

再用debug调试p26课的一个循环程序

GarfieldA 发表于 2019-2-21 16:27:52

我是在调试这段程序的时候遇到的

assume cs:code
code segment

mov ax,2000h
mov ds,ax
mov al,ds:
mov bl,ds:
mov cl,ds:
mov dl,ds:

mov ax,4c00h
int 21h
code ends
end

jackz007 发表于 2019-2-21 16:57:46

   这就明白了,2000:0 ~ 2000:3 是 4 个字节的内存区域,从你的代码来看,你事先并没有将任何数据存储到这个内存区域,也没有对此内存区域进行初始化,也就是说,这片内存区域的内容是随机的,所以,你观察到 al / bl / cl /dl 是任何值都是对的,每一次调试不一样,和小甲鱼老师不一样也同样都是对的。

暗pluto 发表于 2019-2-22 12:03:49

楼上说得很清楚了,代码2000:0~4的四个字节单元中的数据是随机的,不一定都是0,所以,你的答案和小甲鱼的不一样也没问题

tiger_lu 发表于 2019-3-4 16:44:15

因为8086汇编是实地址模式 , 你看到的数据,是以前程序留下的。
实地址就是真实的物理地址,实模式会有以下一些问题:
1. 程序都是全部加载进内存的。容易造成内存不足
2. 内存是真实的地址,容易取到或者修改别的程序的数据。
保护模式可以解决这些问题 , 因为它的地址是假的,当前程序只能看到自己的数据。
页: [1]
查看完整版本: 第五章p26课的一个问题很迷惑