|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
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 //将1送入ax得到 ax=1
mov ds,ax //将数据送入段寄存器ds,是段寄存器指向0001:0(即:00010H这个地址)
mov ax,[0000] ax= 2662H //获取内存地址为0001:0的数据送入ax中,ax为字型数据(16位)得到的数据为00和01,按位从高到低获取得到ax为2662H
mov bx,[0001] bx= E626H //获取内存地址为0001:1的数据送入bx中,ax为字型数据(16位)得到的数据为00和01,按位从高到低获取得到ax为E626H
mov ax,bx ax= E626H //将bx的值送入ax中,ax的值变为E626H
mov ax,[0000] ax= 2662H //获取内存地址为0001:0的数据送入ax中,ax为字型数据(16位)得到的数据为00和01,按位从高到低获取得到ax为2662H
mov bx,[0002] bx= D6E6H //获取内存地址为0001:2的数据送入bx中,bx为字型数据(16位)得到的数据为02和03,按位从高到低获取得到bx为D6E6H
add ax,bx ax= FD48H //将ax和bx相加的数值送入ax中,D6E6+2662=FD48H
add ax,[0004] ax= 2C14H //将ax和0001:4相加的数值送入ax中,2ECC+FD48=2c14H
mov ax,0 ax= 0 //将0送入ax得到 ax=0
mov al,[0002] ax= 00e6H //获取内存地址为0001:0的数据送入al中,ax为字型数据(16位)得到的数据为00和01,al位低位按位从高到低获取得到ax为00e6H
mov bx,0 bx= 0 //将0送入ax得到 ax=0
mov bl,[000c] 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,[0008] CS=FF0H IP=108 DS=2000H AX=C389H BX=0
mov ax,[0002] CS=FF0H IP=10B DS=2000H AX=EA66H BX=0
jmp那里直接跳转到了0ff0:0100(其实就是10000H),所以序列变成了这样。
对了一下答案,发现答案有一个地方错了,就是初始值时它把DS=0了,题目是DS=1000H。
|
|