汇编语言(王爽)第四章第一个程序
4.1一个源程序从编写到执行的过程
第一步:编写汇编源程序;第二步:对源程序进行编译和连接:编译器进行编译,生成目标文件,连接器对目标文件进行连接,生成可执行文件;第三步:执行可执行文件。
4.2源程序
汇编语言源程序中有两种指令:一种是汇编指令,一种是伪指令。汇编指令对应有机器码,可以被编译为机器指令;而伪指令是由编译器来执行的指令,是辅助编译工作的指令,并不转化成机器码,更不会被执行。
程序返回:一个程序要被执行,首先要被加载到内存,然后将CPU控制权交给该程序。比如对于单任务操作系统DOS下,若P1正在执行,要执行P2的话,则P1先要将P2加载到内存,将CPU控制权交给P2,然后P2开始运行,P1暂停。当P2运行结束后,需要将CPU控制权交还给P1,这个交还称之为“程序返回”。汇编指令里的“mov ax,4c00H/int 21H"实现的功能就是程序返回。
与结束相关的指令:
目的 相关指令 指令性质 指令执行者
通知编译器一个段结束 段名 ends 伪指令 编译时编译器执行
通知编译器程序结束 end 伪指令 编译时编译器执行
程序返回 mov ax,4c00H int 21h 汇编指令 执行时由CPU执行
4.9程序执行过程
通过debug可对程序进行单步跟踪,程序加载进入内存后,cx寄存器中存放的是该程序的长度。程序的第一条指令地址即在CS:IP。
在DOS系统中可执行文件的加载过程如下:先找到一段足够容量的内存空闲区域,设其起始地址为SA:0000;在该区域前256个内存单元中创建PSP数据区(这个区主要是DOS系统用来和该程序进行通信);在这256个内存单元之后开始存入程序。
所以,各区域分配如下:
内存空闲区域:SA:0000~;
PSP区:SA:0000~SA:00FF;
程序装载区:(SA+10):0000~;(这里为何不可以是:SA:0100?).
程序加载完毕后,DS设置为SA,CX设置为程序长度。由上可知,CS=SA+10H=DS+10H;