《汇编语言》王爽老师课件.ppt

上传人:牧羊曲112 文档编号:6077678 上传时间:2023-09-20 格式:PPT 页数:61 大小:605KB
返回 下载 相关 举报
《汇编语言》王爽老师课件.ppt_第1页
第1页 / 共61页
《汇编语言》王爽老师课件.ppt_第2页
第2页 / 共61页
《汇编语言》王爽老师课件.ppt_第3页
第3页 / 共61页
《汇编语言》王爽老师课件.ppt_第4页
第4页 / 共61页
《汇编语言》王爽老师课件.ppt_第5页
第5页 / 共61页
点击查看更多>>
资源描述

《《汇编语言》王爽老师课件.ppt》由会员分享,可在线阅读,更多相关《《汇编语言》王爽老师课件.ppt(61页珍藏版)》请在三一办公上搜索。

1、广东海洋大学信息学院计算机科学与技术系,汇编语言课件,王爽 著清华大学出版社主讲-叶晓霞,广东海洋大学信息学院,广东海洋大学信息学院计算机科学与技术系,第4章 第1个程序,4.1 一个源程序从写出到执行的过程4.2 源程序4.3 编辑源程序4.4 编译4.5 连接4.6 以简化的方式进行编译和连接4.7 1.exe的执行4.8 可执行文件中的程序装入内存并运行的原理4.9 程序执行过程的跟踪,广东海洋大学信息学院计算机科学与技术系,引言,现在我们将开始编写完整的汇编语言程序,用编译器将它们编译成为可执行文件(如:*.exe文件),在操作系统中运行。这一章,我们将编写第一个这样的程序。,广东海洋

2、大学信息学院计算机科学与技术系,4.1 一个源程序从写出到执行的过程,一个汇编语言程序从写出到最终执行的简要过程:编写-编译-连接-执行演示,使用文本编辑器(如Edit、记事本等),用汇编语言编写汇编源程序。,使用汇编语言编译程序对源程序进行编译,产生目标文件;再用连接程序对目标文件进行连接,生成可在操作系统中直接运行的可执行文件。,在操作系统中,执行可执行文件中的程序。可执行文件中包含两部分内容:程序(从源程序中的汇编指令翻译过来的机器码)和数据(源程序中定义的数据);相关的描述信息(比如:程序有多大、要占多少内存空间等)。,广东海洋大学信息学院计算机科学与技术系,执行可执行文件中的程序,操

3、作系统依照可执行文件中的描述信息,将可执行文件中的机器码和数据加载入内存,并进行相关的初始化(比如:设置CS:IP指向第一条要执行的指令),然后由CPU执行程序。,广东海洋大学信息学院计算机科学与技术系,广东海洋大学信息学院计算机科学与技术系,4.2 源程序,汇编指令伪指令 XXX segment XXX ends end assume,广东海洋大学信息学院计算机科学与技术系,4.2 源程序,汇编指令有对应的机器码的指令,可以被编译为机器指令,最终为CPU所执行。,广东海洋大学信息学院计算机科学与技术系,4.2 源程序,伪指令没有对应的机器码的指令,最终不被CPU所执行。谁来执行伪指令呢?伪指

4、令是由编译器来执行的指令,编译器根据伪指令来进行相关的编译工作。,广东海洋大学信息学院计算机科学与技术系,定义一个段,segment和ends是一对成对使用的伪指令,这是在写可被编译器编译的汇编程序时,必须要用到的一对伪指令。功能:定义一个段,segment说明一个段开始,ends 说明一个段结束。一个段必须有一个名称来标识,使用格式为:段名 segment 段名 ends一个汇编程序是由多个段组成的,这些段被用来存放代码、数据或当作栈空间来使用。一个有意义的汇编程序中至少要有一个段,这个段用来存放代码。(汇编语言源程序至少要有一个代码段),广东海洋大学信息学院计算机科学与技术系,程序结束标记

5、,End 是一个汇编程序的结束标记,编译器在编译汇编程序的过程中,如果碰到了伪指令 end,就结束对源程序的编译。如果程序写完了,要在结尾处加上伪指令end。否则,编译器在编译程序时,无法知道程序在何处结束。注意:不要搞混了end和ends。,广东海洋大学信息学院计算机科学与技术系,寄存器与段的关联假设,assume:含义为“假设”。它假设某一段寄存器和程序中的某一个用 segment ends 定义的段相关联。通过assume说明这种关联,在需要的情况下,编译程序可以将段寄存器和某一个具体的段相联系。格式 段寄存器:段名,广东海洋大学信息学院计算机科学与技术系,4.2 源程序,源程序中的“程

6、序”汇编源程序:伪指令(编译器处理)汇编指令(编译为机器码)程序:源程序中最终由计算机执行、处理的指令或数据。注意,广东海洋大学信息学院计算机科学与技术系,注意,我们可以将源程序文件中的所有内容称为源程序,将源程序中最终由计算机执行处理的指令或数据,称为程序。程序最先以汇编指令的形式存在源程序中,经编译、连接后转变为机器码,存储在可执行文件中,图示,广东海洋大学信息学院计算机科学与技术系,程序经编译连接后变为机器码,广东海洋大学信息学院计算机科学与技术系,4.2 源程序,标号一个标号指代了一个地址。codesg:放在segment的前面,作为一个段的名称,这个段的名称最终将被编译、连接程序处理

7、为一个段的段地址。,广东海洋大学信息学院计算机科学与技术系,4.2 源程序,程序的结构任务:编程运算 23。定义一个段实现处理任务程序结束段与段寄存器关联,汇编程序 assume cs:abc abc segment mov ax,2 add ax,ax add ax,ax abc ends end,广东海洋大学信息学院计算机科学与技术系,4.2 源程序,程序返回我们的程序最先以汇编指令的形式存在源程序中,经编译、连接后转变为机器码,存储在可执行文件中,那么,它怎样得到运行呢?(讨论)现在,我们知道,一个程序结束后,将CPU的控制权交还给使它得以运行的程序,我们称这个过程为:程序返回。如何返回

8、呢?,广东海洋大学信息学院计算机科学与技术系,DOS中的程序运行,DOS是一个单任务操作系统。一个程序P2在可执行文件中,则必须有一个正在运行的程序P1,将P2从可执行文件中加载入内存后,将CPU的控制权交给P2,P2才能得以运行。P2开始运行后,P1暂停运行。而当P2运行完毕后,应该将CPU的控制权交还给使它得以运行的程序P1,此后,P1继续运行。,广东海洋大学信息学院计算机科学与技术系,4.2 源程序,程序返回应该在程序的末尾添加返回的程序段。mov ax,4c00H int 21H这两条指令所实现的功能就是程序返回。几个和结束相关的内容,广东海洋大学信息学院计算机科学与技术系,段结束、程

9、序结束、程序返回,广东海洋大学信息学院计算机科学与技术系,语法错误和逻辑错误,语法错误程序在编译时被编译器发现的错误;容易发现。aume cs:abc abc segment mov ax,2 add ax,ax add ax,ax end,广东海洋大学信息学院计算机科学与技术系,语法错误和逻辑错误,逻辑错误程序在编译时不能表现出来的、在运行时发生的错误;不容易发现。,assume cs:abc abc segment mov ax,2 add ax,ax add ax,ax mov ax,4c00H int 21H abc ends end,广东海洋大学信息学院计算机科学与技术系,4.3 编

10、辑源程序,进入DOS方式,运行Edit,在其中编辑程序,如下图所示:,广东海洋大学信息学院计算机科学与技术系,4.4 编译,进入DOS方式,进入 C:masm 目录,运行masm.exe。如果源程序文件不是以 asm 为扩展名的话,就要输入它的全名。比如p1.txt。在输入源程序文件名的时候一定要指明它所在的路径。如果文件就在当前路径下,只输入文件名就可以。,广东海洋大学信息学院计算机科学与技术系,4.4 编译,输入要编译的源文件文件名后,按 Enter键。目标文件(*.obj)是我们对一个源程序进行编译要得到的最终结果。编译程序默认要输出的目标文件名为1.obj,所以可以不必再另行指定文件名

11、。,广东海洋大学信息学院计算机科学与技术系,4.4 编译,列表文件是编译器将源程序编译为目标文件的过程中产生的中间结果。可以不生成这个文件,直接按 Enter键即可。,广东海洋大学信息学院计算机科学与技术系,4.4 编译,编译程序提示输入交叉引用文件的名称。这个文件同列表文件一样,是编译器将源程序编译为目标文件过程中产生的中间结果。可以不生成这个文件,直接按 Enter 键即可。,广东海洋大学信息学院计算机科学与技术系,4.4 编译,对源程序的编译结束,编译器输出的最后两行告诉我们这个源程序没有警告错误和必须要改正的错误。,广东海洋大学信息学院计算机科学与技术系,4.4 编译,一般来说,有两类

12、错误使我们得不到所期望的目标文件:(1)我们程序中有“Severe Errors”;(2)找不到所给出的源程序文件。,广东海洋大学信息学院计算机科学与技术系,4.5 连接,在对源程序进行编译得到目标文件后,我们需要对目标文件进行连接,从而得到可执行文件。继续上一节的过程,我们再将C:masm1.obj连接为C:masm1.exe。,广东海洋大学信息学院计算机科学与技术系,4.5 连接,进入DOS方式,进入C:masm目录,运行link.exe。如果目标文件不是以obj为扩展名的话,就要输入它的全名。比如:p1.bin。在输入目标文件名的时候,要注意指明它所在的路径。这里,我们要连接的文件是当前

13、路径下1.obj,所以此处输入“1”。,广东海洋大学信息学院计算机科学与技术系,4.5 连接,输入要连接的目标文件名后,按Enter键。可执行文件是我们对一个程序进行连接要得到的最终结果。连接程序默认要输出的可执行文件名为 1.EXE,所以可以不必再另行指定文件名。我们直接按 Enter 键,使用连接程序设定的可执行文件名。,广东海洋大学信息学院计算机科学与技术系,4.5 连接,映像文件是连接程序将目标文件连接为可执行文件过程中产生的中间结果。可以不生成这个文件,直接按 Enter 键即可。,广东海洋大学信息学院计算机科学与技术系,4.5 连接,连接程序提示输入库文件的名称。库文件里包含了一些

14、可以调用的子程序,如果我们的程序中调用了某一个库文件中的子程序,就需要在连接的时候,将这个库文件和我们的目标文件连接到一起,生成可执行文件。如果没有调用任何子程序,直接按Enter键即可。,广东海洋大学信息学院计算机科学与技术系,4.5 连接,对目标文件的连接结束,连接程序输出的最后一行告诉我们,这个程序有一个警告错误:“没有栈段”,这里我们不理会这个错误。,广东海洋大学信息学院计算机科学与技术系,4.5 连接,前面我们通过对 1.obj 进行连接的过程,展示了使用连接器对目标文件进行连接的方法。我们得到了一个新的文件 1.exe。当然,如果连接过程中出现错误,那么我们将得不到这个可执行文件。

15、连接的作用是什么呢?,广东海洋大学信息学院计算机科学与技术系,4.5 连接,这里再次强调一下,我们学习汇编的主要目的,就是通过用汇编语言进行编程而深入地理解计算机底层的基本工作机理,达到可以随心所欲地控制计算机的目的。基于这种考虑,我们的编程活动,大都是直接对硬件进行的。我们希望直接对硬件编程,却并不希望用机器码编程。我们用汇编语言编程,就要用到:编辑器(Edit)、编译器(masm)、连接器(link)、调试工具(debug)等所有工具,而这些工具都是在操作系统之上运行的程序,所以我们的学习过程必须在操作系统的环境中进行。,广东海洋大学信息学院计算机科学与技术系,4.5 连接,连接的作用有以

16、下几个:当源程序很大时,可以将它分为多个源程序文件来编译,每个源程序编译成为目标文件后,再用连接程序将它们连接到一起,生成一个可执行文件;程序中调用了某个库文件中的子程序,需要将这个库文件和该程序生成的目标文件连接到一起,生成一个可执行文件;,广东海洋大学信息学院计算机科学与技术系,4.5 连接,连接的作用有以下几个(续):一个源程序编译后,得到了存有机器码的目标文件,目标文件中的有些内容还不能直接用来生成可执行文件,连接程序将这些内容处理为最终的可执行信息。所以,在只有一个源程序文件,而又不需要调用某个库中的子程序的情况下,也必须用连接程序对目标文件进行处理,生成可执行文件。注意,对于连接的

17、过程,可执行文件是我们要得到的最终结果。,广东海洋大学信息学院计算机科学与技术系,4.6 以简化的方式进行编译和连接,我们编译、连接的最终目的是用源程序文件生成可执行文件。在这个过程中所产生的中间文件都可以忽略。我们可以用一种较为简捷的方式进行编译、连接。,广东海洋大学信息学院计算机科学与技术系,4.6 以简化的方式进行编译和连接,编译:,广东海洋大学信息学院计算机科学与技术系,4.6 以简化的方式进行编译和连接,连接:,广东海洋大学信息学院计算机科学与技术系,4.7 1.exe的执行,现在,终于将我们的第一个汇编程序加工成了一个可在操作系统下执行的程序文件。1.exe的执行情况:程序到底运行

18、没有?程序当然运行了,只是从屏幕上不可能看到任何运行结果。,广东海洋大学信息学院计算机科学与技术系,4.7 1.exe的执行,我们的程序没有像显示器输出任何信息。程序只是做了一些将数据送入寄存器和加法的操作,而这些事情,我们不可能从显示屏上看出来。程序执行完成后,返回,屏幕上再次出现操作系统的提示符。,广东海洋大学信息学院计算机科学与技术系,4.8 可执行文件中的程序装入内存并运行的原理,在DOS中,可执行文件中的程序P1若要运行,必须有一个正在运行的程序P2,将 P1 从可执行文件中加载入内存,将CPU的控制权交给它,P1才能得以运行;当P1运行完毕后,应该将CPU的控制权交还给使它得以运行

19、的程序P2。1.exe的执行过程,广东海洋大学信息学院计算机科学与技术系,4.8 可执行文件中的程序装入内存并运行的原理,1.exe的执行过程:(1)我们在提示符“C:masm”后面输入可执行文件的名字“1”,按Enter键。问题4.1(2)1.exe中的程序运行;(3)运行结束,返回,再次显示提示符“C:masm”。问题4.2,广东海洋大学信息学院计算机科学与技术系,问题4.1,执行第(1)步操作时,有一个正在运行的程序将1.exe中的程序加载入内存,这个正在运行的程序是什么?它将程序加载入内存后,如何使程序得以运行?,广东海洋大学信息学院计算机科学与技术系,问题4.2,执行第(3)步操作,

20、程序运行结束后,返回到哪里?参考内容回答问题4.1和4.2,广东海洋大学信息学院计算机科学与技术系,操作系统的外壳,操作系统是由多个功能模块组成的庞大、复杂的软件系统。任何通用的操作系统,都要提供一个称为shell(外壳)的程序,用户(操作人员)使用这个程序来操作计算机系统工作。DOS中有一个程序,这个程序在 DOS 中称为命令解释器,也就是DOS系统的shell。,广东海洋大学信息学院计算机科学与技术系,回答问题4.1和4.2,(1)我们在DOS中直接执行 1.exe 时,是正在运行的command将1.exe中的程序加载入内存。(2)command设置CPU的CS:IP指向程序的第一条指令

21、(即程序的入口),从而使程序得以运行。(3)程序运行结束后,返回到command中,CPU继续运行command。,广东海洋大学信息学院计算机科学与技术系,汇编程序从写出到执行的过程:,广东海洋大学信息学院计算机科学与技术系,4.9 程序执行过程的跟踪,为了观察程序的运行过程,我们可以使用Debug。Debug 可以将程序加载入内存,设置CS:IP指向程序的入口,但Debug并不放弃对CPU 的控制,这样,我们就可以使用Debug 的相关命令来单步执行程序,查看每条指令指令的执行结果。,广东海洋大学信息学院计算机科学与技术系,4.9 程序执行过程的跟踪,接下来可以用R命令看一下各个寄存器的设置

22、情况:可以看到,Debug将程序从可执行文件加载入内存后,cx中存放的是程序的长度。1.exe 中程序的机器码共有15个字节。,广东海洋大学信息学院计算机科学与技术系,4.9 程序执行过程的跟踪,现在程序已从 1.exe 中装入内存,接下来我们查看一下它的内容,可是我们查看哪里的内容呢?程序被装入内存的什么地方?我们如何得知?在DOS系统中.EXE文件中的程序的加载过程如下,广东海洋大学信息学院计算机科学与技术系,EXE文件中的程序的加载过程,广东海洋大学信息学院计算机科学与技术系,EXE文件中的程序的加载过程,总结程序加载后,ds中存放着程序所在内存区的段地址,这个内存区的偏移地址为 0,则

23、程序所在的内存区的地址为:ds:0;这个内存区的前256(100H)个字节中存放的是PSP,dos用来和程序进行通信。从 256字节处向后的空间存放的是程序,所以程序的物理地址是:SA16+0+256=SA16+1616=(SA+16)16+0 可用段地址和偏移地址表示为:SA+10:0 即cs=ds+10h,ip=0。,广东海洋大学信息学院计算机科学与技术系,4.9 程序执行过程的跟踪,用U命令查看一下其他指令:,广东海洋大学信息学院计算机科学与技术系,4.9 程序执行过程的跟踪,用T命令单步执行程序中的每一条指令,并观察每条指令的执行结果,到了 int 21,我们要用P命令执行:,广东海洋

24、大学信息学院计算机科学与技术系,4.9 程序执行过程的跟踪,int 21 执行后,显示“Program terminated normally”,返回到Debug中。表示程序正常结束。那程序返回哪里呢?,广东海洋大学信息学院计算机科学与技术系,4.9 程序执行过程的跟踪,我们在 DOS中用“Debug 1.exe”运行Debug对1.exe进行跟踪时,程序加载的顺序是:command加载Debug,Debug加载1.exe。返回的顺序是:从1.exe中的程序返回到Debug,从Debug返回到command。使用Q命令退出Debug,将返回到command中,因为Debug是由command加载运行的。,

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 生活休闲 > 在线阅读


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号