汇编实验3

练习1

第1步,编写汇编源程序t1.asm, 源程序代码如图所示。

1351634-20181117093635776-1372585533.png

第2步——(1)运行结果:输出数字36

1351634-20181117093849573-143053489.png

(2)将line4和line9的寄存器dl值改为6和8:结果输出数字68

推测:本段代码含义为输出line4和line9的寄存器dl中的数字

1351634-20181117094346203-824589382.jpg
1351634-20181117094355283-1300035725.png

(3)debug调试该文件

① 使用 r 命令查看。观察寄存器 cx 的值是 多少;观察寄存器 ds 和 cs 的值是多 少,它们之间是否满足关系(cs)=(ds)+10H? 结果如下图

1351634-20181117094654260-885435232.png

② PSP(程序段前缀)的头两个字节是CD 20, 用debug查看PSP的内容是否如此

1351634-20181117094819632-372903929.png

③使用 u 命令对 t1.exe 进行反汇编

1351634-20181117095006682-2018723957.png

④ 使用 t 命令和 p 命令(遇到 int 命令时,用 p 命令)单步调试

1351634-20181117095128167-1025586916.png

1351634-20181117095134010-2061422251.png

1351634-20181117095137822-473182587.png

练习2

(1)编写如下程序

1351634-20181117100443431-392889618.png

结果为:左上角输出红色的数字36

1351634-20181117100510806-1488192984.png

(2)试将源代码中line7的0433h→0432h, line10 的 0436h→0439h

结果为:左上角输出红色的数字29

1351634-20181117100856379-1867617880.png

(3)将源代码中line7的0433h→0333h, line10 的 0436h→0336h,

结果为:左上角输出蓝色的数字36

1351634-20181117101138452-205947915.png

推测:line7和line10分别控制着输出数字的第一位和第二位,诸如0439h,其中04两位控制输出颜色,39两位控制输出的数字

转载于:https://www.cnblogs.com/MrWang-nextdoor/p/9972934.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值