第三章 寄存器(内存访问)

检测点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和相关寄存器的数值。

commandCSIPDSAXBX
mov ax,662H2000H3H06622H0
jmp 0ff0:0100ff0H100H06622H0
mov ax,2000Hff0H103H02000H0
mov ds,axff0H105H2000H2000H0
mov ax,[0008]ff0H108H2000HC389H0
mov ax,[0002]ff0H111H2000HEA66H0

(第一遍还是要参考答案捋,有些细节点老是忘记,导致联通不上)

③ 再次体会:数据和程序有区别吗?如何确定内存中的信息哪些是数据,哪些是程序?
对于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]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值