当前位置:文档之家› 如何编写和汇编语言程序

如何编写和汇编语言程序

如何编写和汇编语言程序可以用普通文本编辑器编辑汇编语言源程序。

常用的有 MS-DOS 下的 EDIT 文本编辑程序, Windows 下的写字板( WORDPAD.EXE )等。

用户通过屏幕编辑程序键入源程序,检查无误,可将源程序存到汇编系统盘上,该程序的扩展名为· ASM 。

软件运行基本环境运行汇编程序必备的软件环境: DOS 操作系统;汇编系统。

汇编系统盘应包含如下文件:MASM 宏汇编程序文件LISK 连接程序文件CRFF 索引程序文件(也可不用)汇编源程序编写1 )源程序的书写格式当 CPU 访问内存时,是把存储器分成若干个段,通过 4 个段寄存器中存放的地址对内存储器访问,因此在编源程序时必须按段的结构来编制程序。

由于每个段的物理空间为≤ 64KB ,所以程序中各段可以分别为一个或几个。

源程序的书写一般有如下形式:逻辑堆栈段堆栈段名 SEGMENT STACK用变量定义预置的堆栈空间··堆栈段名 ENDS逻辑数据段数据段名 SEGMENT用变量定义预置的数据空间··数据段名 ENDS逻辑代码段代码段名 SEGMENTASSUME 定义各段寻址关系过程名 PROC …程序··过程名 ENDP代码段名 ENDSEND 过程名或起始标号在源程序中最少要有一个代码段,数据段根据需要可有可无,也可以增设附加段。

对于堆栈段也可以根据需要可有可无,但在连接( LINK )时计算机将显示警告性的错误:Warning : N STACK segmentThere was 1 error detected.在程序中如果没有用到堆栈时,该错误提示不影响程序的运行,如果程序中用到堆栈时必须设置堆栈段。

其中: SEGMENT 、 ASSUME 、 PROC … ENDP 为伪指令,伪指令是发给汇编程序 ASM 的,而不和微处理器打交道,在汇编时不产生目标代码,只是把源程序中各段的设置情况告诉汇编程序。

2 )段寄存器的段地址的装入Assume 伪指令语句只是建立了当前段与段寄存器的联系,但不能把各段的段地址装入相应的段寄存器中,段寄存器的段地址的装入是在程序中完成的。

( 1 ) DS 、 ES 、 SS 的装入由于段寄存器不能用立即数寻址方式直接传送,所以段地址装入可通过通用寄存器传送给段寄存器。

MOV AX ,逻辑段名MOV 段寄存器, AX其中逻辑段名为程序中定义各逻辑段的名字,(不包括代码段),段寄存器是指与各逻辑段相对应的各段寄存器( DS 、ES 、 SS )。

( 2 ) CS 的装入代码段寄存器是装当前执行目标代码的段地址, IP 是提供下一条要执行的目标代码的偏移量,为了保证程序的正确执行, CS 和 IP 装入新值时是一起完成的。

对 CS 和 IP 的装入有如下几种情况:①根据用户程序中的伪指令 END 后的标号为 CS 和 IP 提供代码段的段地址和目标代码的偏移地址。

②在程序运行过程中,当执行某些指令和操作时, CPU 自动修改 CS 和 IP 的值,使它们指向新的代码段。

3 )程序中的数据与变量在汇编源程序中的数据除了立即数,由指令产生的数和通过键盘输入的数以外,还胡大量的数据是通过伪指令语句进行预置和分配的,也就是在某逻辑段中(除代码段),将所需的数据以某种形式存放起来,在程序中可任意调用。

在数据定义的同时还可以定义变量,将变量与数据结合在一起。

可以为某个变量分配存储空间以便在程序执行过程中存放中间结果和最终结果,使用起来极为方便。

(1)变量与数据的定义变量与数据的定义可以通过符号定义伪指令 EQU 、=和数据定义伪指令 DB 或 DW 或 DD 来实现。

EQU 和=可以出现在程序的逻辑段内也可出现在逻辑段外。

(2)汇编程序中数据的提供方法①用数据定义伪指令提供数据如果程序要求原始数据为一批数据时,用数据定义伪指令 DB 、 DW 和 DD 来提供较为方便。

②用立即数的形式提供数据当原始数据只有几个时,一般用立即数的方法来提供。

当然,用立即数的方法只是将一个数据传送到通用寄存器中,它只是通过通用寄存器传送数据。

③用编程的方法提供数据假如原始数据是一组有规律的数据项,则用编程序的方法形成这一组数据,不用专门为这组数据分配存储单元,节省了存储空间。

④用键盘提供数据当原始数据为任意数据时,一般用键盘输入方法,调用 DOS 21H 中断。

(3)数据的输出方式①在显示器上显示一个字符调用 02H 号功能调用号,发 21H 号中断,将要显示的字符的 ASCII 码送入 DL ,就可在显示器上显示该字符。

②在打印机上输出一个字符调用 05H 号功能调用号,发 21H 号中断,将要打印字符的 ASCII 码送入 DL ,就可在打印机上打印出 DL 中的字符。

4)返回 DOS 状态的方法当执行 .EXE 文件时,是在 DOS 状态下进行的,如果希望在执行完 .EXE 文件后正常返回 DOS 状态,一般用如下两种方法:采用 DOS 4CH 功能调用和采用返回( RET )断点的方法。

汇编处理—执行宏汇编程序 MASM.EXE用汇编语言编写的源程序必须是一个完整的源程序。

宏汇编程序对汇编语言源程序的汇编过程包括语法检查和数据代码汇编两部分,生成目标程序和辅助信息文件。

为了完成汇编任务,汇编程序一般采用两遍扫描的方法,第一遍扫描源程序产生符号表、处理伪指令等,第二遍扫描产生机器指令代码、确定数据等。

源程序用宏汇编程序翻译(汇编)后,可以得到三个文件:一个是扩展名为 .OBJ 的目标文件,在该文件中,将源程序的操作码部分变为机器码,但地址操作数是可浮动的相对地址,而不是实际地址,因此需经 LINK 连接文件进行连接才能形成可执行文件。

第二个文件是列表文件,扩展名为 .LST ,它把源程序和目标程序列表,以供检查程序用。

第三个文件是交叉索引文件,扩展名为 .CRF ,它是一个对源程序所用的各种符号进行前后对照的文件。

其中目标文件是必须产生的,而其它两个文件在需要时给予命令就可产生,对连接和执行汇编程序无直接的关系。

1 )汇编操作过程在 DOS 状态下,键入 MASM ↓则调入宏汇编程序,屏幕显示与操作如下:masm ↓Microsoft ( R ) Macro Assemble Version 5.00Copyright ( C ) Microsoft Corp 1981-1985,1987,All right reserved.Source filename [.ASM ]: MYFILE ↓Object filename [MYFILE.OBJ ]: MYFILE ↓Source listing [NUL.LST ]: MYFILE ↓Cross-reference [NUL.CRF]: MYFILE ↓50678 + 410090 Bytes symbol space free0 Warning Errors0 Severe Errors其中划线部分为用户键入部分, MYFILE 为源程序名( MYFILE.ASM ),方括号中是机器规定的默认文件名,如果用户认为方括号内的文件名就是要键入的文件名,则可只在划线部分键入回车符。

如果不想要列表文件和交叉索引文件,则可在 [NUL.LST ] 和 [NUL.CRF] 后不键入文件名只键入回车符。

当回答完上述四个询问后,汇编程序就对源程序进行汇编。

在汇编过程中,如果发现源程序中有语法错误,则提示出错信息,指出是什么性质的错误,错误类型,最后列出错误的总数。

之后可重新进入屏幕编辑状态,调入源程序( MYFILE.ASM )进行修改,修改完毕,再进行汇编,直到汇编通过为止。

如果在汇编时不需要产生列表文件( .LST )和交叉索引文件( .CRF ),调用汇编程序时可用分号结束。

如果需要产生 .OBJ 和 .LST 文件,不需要 .CRF 文件,则在分号前面加两个逗号即可。

如果 4 个文件都需要,用简便的操作方法是在分号前用了 3 个逗号。

2 )列表文件( .LST )列表文件( .LST )是通过汇编程序( MASM )产生的,可以在 DOS 状态下用 TYPE 命令显示或打印该文件,以便分析调试源程序。

如显示 D 盘上已存在的列表文件 MYFILE.LST 操作方法如下:D> TYPE MYFILE . LST ;↓列表程序由三部分组成:( 1 )源程序和目标程序清单列表程序同时列出源程序和对应的机器语言清单。

列表程序的第一列给出每条指令所在行号;第二列给出从段的首地址开始的每条指令存放的偏移地址;接着是数字列,给出对应每条语句的机器码和对应于存放在栈段和数据段的值,在机器码加上“ R ”的指令表示:这条指令在连接时可能产生与列出来的偏移地址不同的地址,因为这些偏移地址可能与其它模块有关;最右边就是用汇编语言编写的源程序。

( 2 )段信息汇总表在段信息汇总表中列出该程序用了哪几个段,如:代码段 CODE 、数据段 DATA 和堆栈段 STACK ;每个段所占存储空间的长度(字节数);每个段的定位类型,包括 PAGE (页)、 PARA (节)、 WORD (字)和 BYTE (字节),它们表示此段的起始边界要求,即起始边界地址应分别可以被 256 、 16 、 2 和 1 除尽。

该列表清单中是以 PARA 为CODE 段、 DATA 段和 STACK 段的起始边界地址。

最后一列为段的组合类型;段的组合类型是告诉连接程序,本段与其它段的关系,组合类型有 NONE 、 PUBLIC 、 COMMOM 、 AT 表达式、 STACK 和 MEMORY 。

NONE :表示本段与其它段不发生逻辑关系,即每段都有自己的基本地址。

是隐含组合类型。

STACK :表明连接程序首先要把本段与同名同类别的其它段相邻地连接在一起,然后为所有定义为栈段的连接在一起的段,定义一个共同的段基地址,即连接成一个物理段。

在列表程序的源程序中只有一个栈段,在栈段定义中给出了组合类型为 STACK ,因此在段信息汇总表中列出了该项,在本程序中它没有任何意义,因为没有其它栈段与它连接,只是为了说明这个问题而设置的。

( 3 )符号汇总表在列表程序中最后部分列出了符号汇总,是指在源程序中用户定义的符号名、类型、值和所在段。

如果在源程序中存在某些语法错误时,列表文件可提示某条语句有哪些错误,出错提示显示在出错指令行的下面,因此用户可借助列表文件很快地找到错误行,以便调试。

另外由于列表文件给出了各条指令的偏移地址,对和程序时设置断点很方便。

3 )交叉索引文件(. CRF )汇编后产生的交叉索引文件,扩展名为. CRF, 它列出了源程序中定义的符号(包括:标号、变量等)和程序中引用这些符号的情况。

相关主题