检测点3.1
1)在Debug中,用d “0:01f”查看内存,结果如下。
0000:0000 70 80 F0 30 EF 60 30 E2-00 80 80 12 66 20 22 60
0000:0010 60 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 = 0006H
add al,bl AX = 000CH
2)内存中的情况如图3.6所示。
各寄存器的初始值:CS=2000H,IP=0,DS=1000H,AX=0,BX=0;
1.写出CPU执行的指令序列(用汇编指令写出)。
2.写出CPU执行每条指令后,CS,IP和相关寄存器中的数值。
3.再次体会:数据和程序有区别吗?如何确定内存中的信息哪些是数据,那些是程序?
指令 | CS | IP | DS | AX |
mov ax,6622H | 2000H | 0 | 1000H | 6622H |
jmp 0ff0:0100 | 0ff0H | 0100H | 1000H | 6622H |
mov ax,2000H | 0ff0H | 0103H | 1000H | 2000H |
mov ds,ax | 0ff0H | 0105H | 2000H | 2000H |
mov ax,[0008] | 0ff0H | 0108H | 2000H | C389H |
mov ax,[0002] | 0ff0H | 010BH | 2000H | EA66H |
程序和数据在内存中看不出来区别,但是 如果是CS:IP所执行到的内存那就是程序,由其它寄存器比如DS指向的则是数据。
注:DS寄存器存放要访问数据的段地址。
检测点3.2
1)补全下面的程序,使其可以将10000H~1000FH中的8个字,逆序复制到20000H~2000FH中。逆序复制的含义如图3.17所示(图中内存里的数据均为假设)。
注:8个字也就是16个内存单元
段寄存器SS 存放栈顶的段地址
寄存器SP 存放偏移地址
mov ax,1000H
mov ds,ax
(mov ax,2000H)
(mov ss,ax) (ss需要ax寄存器给值)
(mov sp,0010H) (sp不需要ax寄存器给值) 等待解决
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
(mov ax,1000H)
(mov cs,ax)
(mov sp,0) 因为要pop,sp要加,所以sp初始值应该是0
pop [E]
pop [C]
pop [A]
pop [8]
pop [6]
pop [4]
pop [2]
pop [0]
PS
1)把0000:0开始处的16字节按字逆序复制到1000:0,至少按两种方法。
第一种方法:
第二种方法,我想应该是自己手动写入