汝不知者花也 发表于 2020-6-15 13:13:17

3.1作业

1)在DEBUG中,用 "D 0:0 lf" 查看内存,结果如下:

0000:0000   7080F030EF6030E2-0080801266202260

0000:00106226E6D6CC2E3C 3B-ABBA000026066688

下面的程序执行前,AX=0,BX=0,写出每条汇编指令执行完后相关寄存器中的值

mov ax,1                        //将1送入ax得到 ax=1

mov ds,ax                        //将数据送入段寄存器ds,是段寄存器指向0001:0(即:00010H这个地址)

mov ax,ax= 2662H         //获取内存地址为0001:0的数据送入ax中,ax为字型数据(16位)得到的数据为00和01,按位从高到低获取得到ax为2662H

mov bx,bx= E626H         //获取内存地址为0001:1的数据送入bx中,ax为字型数据(16位)得到的数据为00和01,按位从高到低获取得到ax为E626H

mov ax,bx      ax= E626H                 //将bx的值送入ax中,ax的值变为E626H

mov ax,ax= 2662H         //获取内存地址为0001:0的数据送入ax中,ax为字型数据(16位)得到的数据为00和01,按位从高到低获取得到ax为2662H

mov bx,bx= D6E6H         //获取内存地址为0001:2的数据送入bx中,bx为字型数据(16位)得到的数据为02和03,按位从高到低获取得到bx为D6E6H

add ax,bx      ax= FD48H                 //将ax和bx相加的数值送入ax中,D6E6+2662=FD48H

add ax,ax= 2C14H         //将ax和0001:4相加的数值送入ax中,2ECC+FD48=2c14H

mov ax,0       ax=   0                   //将0送入ax得到 ax=0

mov al,ax= 00e6H         //获取内存地址为0001:0的数据送入al中,ax为字型数据(16位)得到的数据为00和01,al位低位按位从高到低获取得到ax为00e6H

mov bx,0       bx=   0                   //将0送入ax得到 ax=0

mov bl,bx= 0026H               //获取内存地址为0001:c的数据送入bl中,bx为字型数据(16位)得到的数据为0c和0d,bl位低位按位从高到低获取得到bx为0026H

add al,bl      ax= 000CH                 //将bl和al相加的树送入ax得到 ax=000cH





①   写出CPU执行的指令序列(用汇编指令写出)。

②   写出CPU执行每条指令后,CS、IP和相关寄存器的数值。

③   再次体会:数据和程序有区别吗?如何确定内存中的信息哪些是数据,哪些是程序?

根据图3.6可得:
mov ax,6222H         CS=2000H         IP=3          DS=1000H      AX=6222H      BX=0

jmp 0ff0:0100      CS=FF0H            IP=100      DS=1000H      AX=6222H      BX=0

mov ax,2000H         CS=FF0H            IP=103      DS=1000H      AX=2000H      BX=0

mov ds,ax            CS=FF0H            IP=105      DS=2000H      AX=2000H      BX=0

mov ax,      CS=FF0H            IP=108      DS=2000H      AX=C389H      BX=0

mov ax,      CS=FF0H            IP=10B      DS=2000H      AX=EA66H      BX=0

jmp那里直接跳转到了0ff0:0100(其实就是10000H),所以序列变成了这样。
对了一下答案,发现答案有一个地方错了,就是初始值时它把DS=0了,题目是DS=1000H。
页: [1]
查看完整版本: 3.1作业