鱼C论坛

 找回密码
 立即注册
查看: 2267|回复: 0

[汇编作业] 3.1作业

[复制链接]
发表于 2020-6-15 13:13:17 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

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。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-4 22:54

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表