RSS

汇编语言程序格式2

来源: 作者: 时间:2007-08-02 Tag: 点击:

汇编语言程序格式

汇编语言源程序用语句书写,MASM中可使用的语句分成两类,他们是指令性语句和伪指令语句

1.指令性语句:指令性语句与机器指令相对应,汇编程序将他翻译成目标代码(机器指令代码)。语句格为:

标号: 指令助记符    操作数,操作数;注释

标号表示指令语句的符号地址,标号后面必须紧跟“:”。标号可以省略,他经常作为转移指令或CALL指令的一个操作数,用以表示地址的转移。

指令助记符是该语句的指令名称的代表号码,他指出操作的类型,汇编程序将其翻译成机器指令。不可省略。

操作数表示参加本指令的运算数据,根据指令的操作类型,操作数不同,中间必须用“,”隔开。

注释指明一条指令的功能,可以省略。

2.伪指令语句

伪指令语句没有对应的机器指令。汇编程序汇编源程序时对伪指令进行处理,他可以完成数据定义,存储区分配,段定义,段分配,指示程序结束功能。伪指令语句的格式为:

名字 伪指令指示符 操作数,操作数;注释

名字时给伪指令取得名称,他用符号地址表示。伪指令中的名字通常是变量名,段名,过程名、符号名等。

伪指令指示符是汇编程序MASM规定的符号。

操作数是根据伪指令的具体要求来得。

3.数据项

汇编语言中使用的操作数,可以是常数、寄存器、存储器、变量、标号活表达式,其中藏书、变量和标号是三种基本数据项。

常数必须是固定的值,没有属性,是确定的数据。

变量在程序运行中是可以修改的。所有的变量具有三种属性

段值(SEGMENT):指明变量所在段的基址。

段内偏移地址(OFFSET):指变量所在地址与段首地址之间的偏移字节数。

类型(TYPE):变量的类型属性指变量中每个单元所包含的字节数,类型有:字节变量(BYTE)、字变量(WORD)、双字变量(DOUBLE WORD

标号:标号是指可执行指令语句的地址的符号表示,他可作为转移指令和调用指令的目标操作数,以确定程序转换的目标地址,他具有三个属性。

段值(SEGMENT):指明标号所在段的基址。

段内偏移地址(OFFSET):指标号所在地址与所在段段首地址之间的偏移字节数。

类型(TYPE):标号的类型属性指在转移指令中标号可转移的距离类型.NEAR,表示近标号只能实现在本代码段内转移或调用;FAR,表示远标号,可;以作为其他代码段中的目标地址,实现段间调用或转移。

伪指令汇总

1.数据定义语句

格式一:变量名  助记符   操作数,操作数;注释

格式二:变量名  助记符    n DUP(操作数,操作数…);注释

功能:将操作数存入变量名指定的存储单元中,或者只分配存储空间不存入数据。

变量名,用符号表示,可以省略。汇编程序时将此变量的助记符后的第一个字节的偏移地址作为他的符号地址。

助记符主要有:

DB:用来定义字节,表示每个操作数占用一个字节;

DW:用来定义字,表示每个操作数占用一个字;

DD:用来定义双字,表示每个操作数占用两个字;

DQ:用来定义四个字,表示每个操作数占用四个字;

DT:用来定义十个字节,表示每个操作数占用十个字节;

在格式二中,用n DUP表示时,n必须是整数,表示括号中的操作数的重复次数。DUP后面必须带括号。

2.表达式赋值语句

赋值语句EQU

格式:符号名  EQU  表达式

功能:用来给变量、标号、常数、指令、表达式等定义一个符号名,程序中用到EQU左边得变量、标号时可以用右边的常数值或表达式来代替,但是一经定义在同一个程序模块中不能再重新定义。

符号语句=

符号语句“=”与EQU语句具有相同功能,区别仅在于EQU中左边的标号不允许重新定义,而用“=”定义的语句可以重新定义。

3段定义语句

存储器的物理地址由段基址和偏移地址组合而成,任何一个逻辑段,无论是数码段,数据段,堆栈段,附加段都必须定义。以便连接程序把不同段和模块连成一个可执行的程序。

段定义语句SEGMENT…ENDS

格式:段名  SEGMENT  定位类型  组合类型  分类名

逻辑段内容

段名   ENDS

  功能:将一个逻辑段定义成一个整体

段名,是逻辑段的标识符,不能省略。他确定了逻辑段在存储器中的地址。必须以SEGMENT开始,以ENDS结束,前后段名必须一致。

定位类型,定位类型参数是对该段起始地址的定位。定位类型参数主要有下面4种:

PARA:指定定位段的起始地址必须在节的整数边界,当定位类型缺省时,就当成PARA

BYTE:指定定位段的起始地址定位在存储单元的任何字节地址。

WORD:指定定位段的起始地址定位在字的边界,即段的首地址必须是偶数。

PAGE:指定定位段的起始地址定位在页的边界,即段的首地址必须是256的整数倍。

组合类型:组合类型参数主要提供了各个逻辑段之间的组合方式

NONE:该段与其他同名段不进行连接,各段独立于存储器中,NONE可作为缺省参数。

PUBLIC:该段与其他模块中的同名段连接时,由低地址到高地址连接起来,组成一个逻辑段,连接次序由连接命令指定。

COMMON:该段在连接时与其他模块中的同名段有相同的起始地址,采用覆盖的方式在存储器中存放,连接长度为各分段中最大长度。

AT表达式:定位该段的起始地址在表达式所指定的节(16的整数倍)边界上。当用户要求某个逻辑段在指定节的边界上时,就要用AT参数来实现。

STACK:指定该段为堆栈段,此参数在堆栈段中不可省略。

MEMORY:定位该段与其他模块中的同名段有相同的首地址,采用覆盖的方法在存储器中组合连接。其功能与COMMON相似,区别是第一个带MEMORY参数的逻辑段覆盖在其他同名段的最上层,其他带此参数的同名段按照COMMON方式处理。

“分类名”(CLASS NAME

其主要作用是汇编程序连接时将所有的分类名相同的逻辑段组成一个段组。

2.段分配语句(ASSUME

格式:ASSUME CS:段名,DS:段名,SS:段名,ES:段名

功能:定义4个逻辑段,指明段和寄存器的关系。

3.过程定义语句

格式:过程名   PROC   属性

过程内容

RET    N

过程名   ENDP

功能:定义一个过程,主程序可以用CALL 指令调用他

过程名:给所定义的过程取得名字,不可省略。象标号一样具有三个属性:段属性、偏移地址属性和距离属性。

RET N为过程内部的返回指令。过程中至少一条RET,可以在任何位置,使过程返回到主程序调用他的CALL指令之下的一条指令。N为弹出值,可以缺省,表示从程返回以后,堆栈中应有N个字节的值作废。

4.程序开始和结束语句

NAME:

格式:NAME   程序名

功能:为源程序目标模块赋名字。

TITLE

格式:TITLE 文本名

功能:将文本名赋给源程序目标模块作名字,功能同NAM..

ORG

格式:ORG  表达式

功能:给汇编程序设置位置指针,指定下面语句的起始偏移地址。

END

格式:END  标号名

功能:标记汇编源程序结束

5.外部伪指令及对准伪指令

程序中包含多个模块时,有些程序或数据在各个模块间要相互共享,可用外部伪指令PUBLICEXTRN来实现此功能。

外部伪指令

PUBLIC用来定义共享模块,EXTAN用来调用共享模块

格式:PUBLIC   名称,名称,

EXTRN   名称:类型,名称:类型

对准伪指令

格式:EVEN

功能:EVEN伪指令使下一语句的地址调整为偶地址

LABEL

LABEL伪指令给已定义的变量或标号取另一个名字,并可重新定义他的类属性

格式:名称   LABEL   类型属性


1.部分资源来自网络,经ET电子归类整理,旨在服务电子爱好者并无商业目的,不保证正确性与完整性.
2.如果您觉得本站资源对您有用,请告知您的好友,用搜索引擎搜"ET电子"即可.


最新评论共有 0 位网友发表了评论
发表评论
评论内容:不能超过250字,需审核,请自觉遵守互联网相关政策法规。
用户名: 密码:
匿名?
注册
教程下载