检测点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,至少按两种方法。

第一种方法:

汇编语言第三章检测题

汇编语言第三章检测题

汇编语言第三章检测题

第二种方法,我想应该是自己手动写入

相关文章:

  • 2021-10-06
  • 2021-04-09
  • 2022-12-23
  • 2021-05-20
  • 2021-04-29
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2021-06-19
  • 2021-04-29
  • 2021-06-28
  • 2021-11-09
  • 2022-12-23
  • 2021-09-18
  • 2021-05-07
相关资源
相似解决方案