第五章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
楼主,你在说什么,想办法让我们听明白。
上传不了图片我只能手打出来了 本帖最后由 jackz007 于 2019-2-21 16:02 编辑
GarfieldA 发表于 2019-2-21 15:59
上传不了图片我只能手打出来了
解决问题的第一步,你应该让别人能再现你遇到的问题。
你用 debug 在干什么,是调试一个程序,还是键入一段代码再跟踪?把来龙去脉交代清楚。 jackz007 发表于 2019-2-21 16:00
解决问题的第一步,你应该让别人能再现你遇到的问题。
你用 debug 在干什么,是调试一个程 ...
再用debug调试p26课的一个循环程序 我是在调试这段程序的时候遇到的
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 这就明白了,2000:0 ~ 2000:3 是 4 个字节的内存区域,从你的代码来看,你事先并没有将任何数据存储到这个内存区域,也没有对此内存区域进行初始化,也就是说,这片内存区域的内容是随机的,所以,你观察到 al / bl / cl /dl 是任何值都是对的,每一次调试不一样,和小甲鱼老师不一样也同样都是对的。
楼上说得很清楚了,代码2000:0~4的四个字节单元中的数据是随机的,不一定都是0,所以,你的答案和小甲鱼的不一样也没问题 因为8086汇编是实地址模式 , 你看到的数据,是以前程序留下的。
实地址就是真实的物理地址,实模式会有以下一些问题:
1. 程序都是全部加载进内存的。容易造成内存不足
2. 内存是真实的地址,容易取到或者修改别的程序的数据。
保护模式可以解决这些问题 , 因为它的地址是假的,当前程序只能看到自己的数据。
页:
[1]