实验 3 编程,编译,链接,跟踪

1、实验目的

1.  掌握汇编语言源程序(8086 dos 汇编)编写→汇编→连接→调试的方法编程

2.  加深对 1-4 章基础知识的理解学习

 

2、实验准备

1. 结合第 4 章课件和教材,学习/复习完整汇编源程序编写→汇编→链接→运行→调试 的方法测试

2.  复习第 1-3 章如下基础知识:spa

(1)寄存器用法操作系统

①  通用寄存器 AX, BX,CX, DXdebug

② 段寄存器 CS, DS, SS 和两个特殊寄存器 IP, SP3d

(2)内存访问,特别是多字节数据的存、取调试

(3)汇编指令用法,注意其合法使用形式blog

①  数据传送类指令:mov, push, pop内存

②  算术运算指令:add, sub

③ 转移类指令:jmp

3、实验内容

1.  练习 1

(1)编写汇编源程序 t1.asm

为了方便后续操做,选择在masm.exe,link.exe同文件夹下用notepad编写该汇编程序,将文件后缀名更改成.asm

(2)对源程序 t1.asm 进行汇编、链接、运行、调试 (1) 运行程序,观察程序输出结果是什么

(显然咱们须要使用DS Box来完成这次实验,实验前依然须要挂载,这个操做在第一次实验时就有过,

这次步骤就省去不表示。)

为了不在编译,链接过程当中产生一些中间文件的过程,这里在语句后面加一个分号

能够看出运行结果是输出了36

(3)  line4  line9 种寄存器 dl 的值分别修改成 0~9 中任何一个数字,从新汇编→ 链接→运行,观察结果的变化。

 随机的修改数字

尽管在语句后加分号省去了生成编译,链接中间文件的过程,但这些相同的步骤依然很麻烦,能够省去

在notepad中写入以下代码,命名为process,后缀改成.bat

在这里发现编译,链接,执行的过程都已经省去,只须要输入process t1

在分别修改了数字后发现输出结果改变了,尽管这段代码还不太理解,但能够大体知道,这两行

应该是决定了输出的结果

(4)   debug 对生成的可执行文件  t1.exe 进行调试。

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

寄存器CX的值是16,代表这段代码的机器码长度是16。

DS=075a,CS=076a。必然的二者相差10h,即知足(cs)=(ds)+10H,

也就是说PSP区:075a:0,程序区:076a:0

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

使用d命令查看075a(即DS寄存器)开始的内存中的内容,显然前十个长度的内存内容为PSP区内容,确实头两个字节为CD 20

③ 使用 u  命令对 t1.exe   进行反汇编,观察反汇编获得的源代码。

程序入口地址CS:IP=076a:0,而CX=16表示的是程序机器码长度,因此在反汇编时能够准确反汇编出程序段内容

④ 使用 t  命令和 p  命令(遇到 int  命令时,用 p    命令)单步调试,观察结果。

这里没有什么异常,程序按顺序步骤执行,遇到int用p指令,最终正常终止

这里除了CS:IP的值发生了改变,AX,BX寄存器的值也发生了改变。

2.  练习 2

(1)编写汇编源程序 t2.asm

为了方便后续操做,选择在masm.exe,link.exe同文件夹下用notepad编写该汇编程序,将文件后缀名更改成.asm

 

(2)对源程序  t2.asm 进行汇编、链接、运行、调试

(3) 对 t2.asm 进行汇编、链接后,获得可执行文件 t2.exe。运行 t2.exe,观察程序运行 结果,验证是否在屏幕左上方出现红色的数值 36。

注*)经测试,有些平台在 dosbox 下运行这个程序时有些问题,若是屏幕左上方没有 输出结果,请运行程序 t2.exe 前,先输入 cls 命令清空一下屏幕,而后再执行 t2.exe。

在使用process.bat一次性编译,链接,执行后发现并无出现预期的红色36

在清屏终于出现了预期的结果,在屏幕左上方出现了红色的36

 

(4) 若是(1)结果获得验证,从新打开 t2.asm,尝试将源代码中 line7 的 0433h0432hline10 0436h0439h, 而后从新汇编、链接,获得可执行文件 t2.exe。使用 cls 命令清 屏后,再次观察程序运行结果。

 

在修改后再次运行,发如今左上方仍然出现了红色的36

(5) 若是(1)结果获得验证,从新打开 t2.asm,尝试将源代码中 line7 的 0433h0333hline10 0436h0336h, 而后从新汇编、链接,获得可执行文件 t2.exe。使用 cls 命令清 屏后,再次观察程序运行结果。

这次在左上方出现了蓝色的36

 

4、总结与体会

1.在以前的实验中因为只是在学习操做记忆Debug的各类命令,感受很枯燥;

但在此次实验后发现Debug调试在汇编程序的查错过程当中颇有帮助

2.任何重复的机械的操做均可以化繁为简,咱们减小没必要要无心义的操做。

3.一个简单的汇编程序实现起来并不容易,汇编语言写程序和高级语言有很大区别

,但也有类似的地方。

4.咱们学习汇编语言是为了直接控制重重覆盖的操做系统软件下的硬件

相关文章
相关标签/搜索