检测点3.1
(1) 在DEBUG中,用 "D 0:0 lf" 查看内存,结果如下: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= 0
mov al,[0002] ax= 00E6H
mov bx,0 bx= 0
mov bl,[000c] bx= 0026H
add al,bl ax= 0000CH
(2) 内存中的情况如图3.6所示
各寄存器的初始值:cs=2000H,ip=0,ds=1000h,ax=0,bx=0;
① 写出CPU执行的指令序列(用汇编指令写出)
② 写出CPU执行每条指令后,CS、IP和相关寄存器的数值。
command | CS | IP | DS | AX | BX |
---|---|---|---|---|---|
mov ax,662H | 2000H | 3H | 0 | 6622H | 0 |
jmp 0ff0:0100 | ff0H | 100H | 0 | 6622H | 0 |
mov ax,2000H | ff0H | 103H | 0 | 2000H | 0 |
mov ds,ax | ff0H | 105H | 2000H | 2000H | 0 |
mov ax,[0008] | ff0H | 108H | 2000H | C389H | 0 |
mov ax,[0002] | ff0H | 111H | 2000H | EA66H | 0 |
(第一遍还是要参考答案捋,有些细节点老是忘记,导致联通不上)
③ 再次体会:数据和程序有区别吗?如何确定内存中的信息哪些是数据,哪些是程序?
对于CPU执行而言,无差别。要看我们如何分段定义,并执行哪些指令。
根据DS段寄存器存储的数据段号值来确定数据段的起始位置(DS * 16)
根据CS段寄存器存储的代码段号值与IP寄存器偏移量值来确定下一条指令的位置(CS * 16 + IP)
检测点3.2
(1)补全下面的程序,使其可以将10000H~1000FH中的8个字,逆序复制20000H~2000FH中。mov ax,1000H
mov ds,ax
# Write here
mov ax,2000H
mov ss,ax
mov sp,0010H
# End
push [0]
push [2]
push [4]
push [6]
push [8]
push [A]
push [C]
push [E]
(2)补全下面程序,使其可以将10000H~1000FH中的8个字,逆序复制到20000H~2000FH中。
mov ax,2000H
mov ds,ax
# Write here
mov ax 1000H
mov ss,ax
mov sp,0H
# End
pop [E]
pop [C]
pop [A]
pop [8]
pop [6]
pop [4]
pop [2]
pop [0]