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]