汇编语言第一篇
在DEBUG中,用 ‘D0:0 lf’ 查看内存,结果如下:
0000:0000 70 80 F0 30 EF 60 30 E2- 00 80 80 12 66 20 22 600000:0010 62 26 E6 D6 CC 2E 3C 3B-AB BA 00 00 26 06 66 88下面的程序执行前,AX=0,BX=0,写出每条汇编指令执行完后相关寄存器中的值mov ax,1mov ds,axmov ax,[0000] ax=?
开始
mov ax,1 mov ds,ax
明显是把ds寄存器改为0001,
那后一条命令操作的代码段地址应该是0001:0000 - 0001:ffff
所谓的段地址和偏移地址,并不是内存中真实存在分段,分段只是cpu去分,为了8086数据传送的设计而已。真实的内存中的数据,还是要以物理地址为准,
那么:ds=0001,所以在逻辑上,之后的内存访问都会在0001:0000-0001:ffff中进行,可以算一下题目中给的:0000:0010物理地址为:000010+0010= 00010而此时ds=0001,0001:0000的物理地址为:000110 + 0000 = 00010可以看到,这二个数据的物理地址是相同的,也就是说,题目最开始其实就已经给出了0001:0000这个内存单元中的真实数据了,就等于0000:0010