检测点 3.1
(1)在Debug中,用“d 0:0 1f”查看内存结果如下。
0000:0000 70 80 F0 30 EF 60 30 E2-00 80 80 12 66 20 22 60
0000:0010 62 26 E6 D6 CC 2E 3C 3B-AB BA 00 00 26 06 66 88
下面的程序执行前,AX=0,BX=0,写出每条汇编指令执行完后相关寄存器中的值。
mov ax,1
mov ds,ax
mov ax,[0000] ;AX=2662H
mov bx,[0001] ;BX=E626H
mov ax,bx ;AX=E626H
mov ax,[0000] ;AX=2662H
mov bx,[0002] ;BX=D6E6H
add ax,bx ;AX=FD48H
add ax,[0004] ;AX=2C14H
mov ax,0 ;AX=0000H
mov al,[0002] ;AX=00E6H
mov bx,0 ;BX=0000H
mov bl,[000C] ;BX=0026H
add al,bl ;AX=000CH
(2)内存中的情况如图3.6所示。
各寄存器的初始值:CS=2000H,IP=0,DS=1000H,AX=0,BX=0;
1)写出CPU执行的指令序列(用汇编指令写出)。
mov ax,6622H
jmp 0ff0:0100
mov ax,2000H
mov ds,ax
mov ax,[0008]
mov ax,[0002]
2)写出CPU执行每条指令后,CS、IP和相关寄存器中的数值。
; 初始时,CS=2000H,IP=0,DS=1000H,AX=0,BX=0
mov ax,6622H ; CS=2000H,IP=0003H,DS=1000H,AX=6622H,BX=0
jmp 0ff0:0100 ; CS=0FF0H,IP=0100H,DS=1000H,AX=6622H,BX=0
mov ax,2000H ; CS=0FF0H,IP=0103H,DS=1000H,AX=2000H,BX=0
mov ds,ax ; CS=0FF0H,IP=0105H,DS=2000H,AX=2000H,BX=0
mov ax,[0008] ; CS=0FF0H,IP=0108H,DS=2000H,AX=C389H,BX=0
mov ax,[0002] ; CS=0FF0H,IP=010BH,DS=2000H,AX=EA66H,BX=0
3)再次体会:数据和程序有区别吗?如何确定内存中的信息哪些是数据,哪些是程序?
内存中的数据和程序没有任何区别。
通过CS:IP指向来区分。
在程序运行过程中,CS:IP所指向的内存地址中的内容为将要执行的指令。
对于没有被CS:IP指向的内存地址,在访问时视为数据。
图3.6 内存情况示意
检测点3.2
(1)补全下面的程序,使其可以将10000H ~ 1000FH中的8个字,逆序复制到20000H ~ 2000FH中。逆序复制的含义如图3.17所示。
图3.17 逆序复制示意图
mov ax,1000H
mov ds,ax
mov ax,2000H
mov ss,ax
mov sp,0010H
push[0]
push[2]
push[4]
push[6]
push[8]
push[A]
push[C]
push[E]
(2)补全下面的程序,使其可以将10000H ~ 10000FH中的8个字,逆序复制到20000H ~ 2000FH中。
mov ax,2000H
mov ds,ax
mov ax,1000H
mov ss,ax
mov sp,0010H
push[E]
push[C]
push[A]
push[8]
push[6]
push[4]
push[2]
push[0]