汇编语言程序设计(四)第一个程序
作者:互联网
目录
汇编语言程序从写出到最终执行的简要过程
- 首先是源程序编写,然后汇编器将源程序汇编成目标文件,然后链接器对目标文件进行链接,生成可在操作系统中直接运行的可执行文件。
- 可执行文件中包含两方面内容:
** 1是程序和数据,程序是从源程序中的汇编指令翻译过来的机器码,数据是源程序中定义的数据。
** 2是相关的描述信息,比如程序有多大,要占多少空间等。 - 操作系统按照可执行文件中的描述信息,将可执行文件中的机器码和数据加载入内容,并进行相关的初始化,比如设置CS:IP指向第一条要执行的指令,然后由CPU执行程序。
汇编源程序内部结构
- 汇编语言源程序主要包括汇编指令和伪指令两部分
汇编指令
- 汇编指令即mov、add等,如图中start下边那一块,汇编指令有对应的机器码,可以被编译成机器指令,最终被CPU执行。
伪指令
- 汇编指令以外的就是伪指令,伪指令没有对应的机器码,不被CPU执行,它不是CPU看的,而是给汇编器看的,伪指令来告诉编译器这一块是什么段,应该怎么样执行。
- 伪指令对segment和ends用于定义一个段,一个段必须要用一个名称来标识,比如图中的codesg segment和codesg ends。
- 一个汇编程序由多个段组成,或者说可以划分成多个段,这些段被用来存放代码、数据或当作栈空间来使用。一个有意义的汇编程序至少有一个段,这个段用来存放代码。
- end是一个汇编程序的结束标记,汇编器在汇编程序的过程中,如果碰到了伪指令end,就结束对源程序的汇编。
- assume用来假设一个段寄存器与程序中某个用segment...ends定义的段相关联,即在需要的情况下汇编程序会将段寄存器和某个具体的段联系起来。如图中用assume来假设代码段寄存器CS与段codesg相关联。
标号
- 一个标号指代了一个地址,比如图中的codesg,放在segment前面,作为一个段的名称,这个段的名称最终汇编、链接后处理为一个段的段地址。注意下图中,应该在end后边加上start,即end start,这个时候start所标识的就是程序的一个入口地址。
源程序中的程序
- 源程序文件中所有内容称为源程序,其中由计算机执行处理的指令或数据,称为程序。程序最先以汇编执行的形式存在源程序中,经过汇编、链接后转变为机器码,存储在可执行文件中。
源程序例子
程序运行过程与返回
-
程序最先以汇编指令形式存在源程序中,经汇编、链接后转变为机器码,存储在可执行文件中,那么怎样得到运行呢?一个可执行文件无法自己开始运行,首先还要由一个正在运行的程序来加载它。即若P2是一个可执行文件,则必须有一个正在运行的程序P1,将P2从可执行文件中加载入内存,将CPU的控制权交给P2,P2才能得以运行,P2开始运行后,P1暂停运行。当P2运行完毕后,将CPU控制权还给使它得以运行的程序P1,此后P1继续运行。
-
一个程序结束后,将CPU控制权还给使它得以运行的程序,这个过程称为:程序返回。
链接的作用
- 源程序很大时,分成多个源程序分别汇编,然后用链接器将它们链接在一起生成可执行文件。
- 程序中调用了某个库文件中的子程序,需要将库文件和该程序的目标文件链接一起生成可执行文件。
- 目标文件中有些内容不能直接用来生成可执行文件,链接程序将这些内容处理为最终的可执行信息,因此即便只有一个源文件,并且不调用库文件,也必须使用链接器进行处理。
操作系统的外壳
- 操作系统时由多个功能模块组成的复杂软件系统,它会提供一个称为shell的程序,用户使用这个程序来操作操作系统工作,比如DOS中有一个程序command.com,即命令解释器,就是DOS系统的shell。
汇编程序从编写到执行的过程
程序被加载到内存的什么地方?
- 如下图中,将程序加载入内存的过程中,DS和CS段寄存器都是使用了的,但是它们的地址相差了10H,它们之间相差的这一部分就是PSP区,即PSP区结束之后才是代码区。PSP区一共256个字节,这个区域称为程序的前缀,操作系统利用PSP区来与被加载程序进行通信。即:
** 程序加载后,DS段寄存器中存放着整个程序所在内存区的段地址,这个内存区的偏移地址为0,即整个程序所在的内存区的地址为DS:0。
** 整个程序内存区的前256个字节存放的是PSP,是dos用来和程序进行通信的一个接口。
** 从256个字节处往后的空间存放的是程序,这个也是CS:IP指向的地址。
标签:可执行文件,汇编,汇编语言,伪指令,程序,链接,程序设计,源程序 来源: https://www.cnblogs.com/chkplusplus/p/16285776.html