汇编语言程序设计及上机指导5汇编语言语法课件_第1页
汇编语言程序设计及上机指导5汇编语言语法课件_第2页
汇编语言程序设计及上机指导5汇编语言语法课件_第3页
汇编语言程序设计及上机指导5汇编语言语法课件_第4页
汇编语言程序设计及上机指导5汇编语言语法课件_第5页
已阅读5页,还剩46页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第5章汇编语言语法【本章提要】本章以Intel系列微处理器的指令系统和宏汇编工具MASM6.X为主体,介绍汇编语言的基本语法和伪指令,实现简单的汇编语言程序设计。【学习目标】·熟练掌握进行汇编语言程序设计的基本语法·熟练掌握伪指令以及宏结构的应用·熟练掌握利用MASM6.X工具对程序进行汇编的具体方法2023/1/16指令:是可执行的,汇编后由相应的机器代码所取代;伪指令:是不可执行的,只是在源程序汇编期间由汇编程序处理的命令,指示汇编程序为数据分配内存空间,或者提供段定义等信息,不产生任何机器代码源程序可执行文件目标模块文本编辑器汇编程序连接程序调试程序机器语言:计算机能够直接识别与执行高级语言:是完全独立于机器的通用语言,效率低,面向过程、面向对象,必须译成机器语言。汇编语言:符号化语言。用指令的助记符、符号地址、标号等编写程序的语言。5.1概述2023/1/165.1.1汇编语言程序的基本概念指令与伪指令的集合构成汇编语言语句

.MODELSMALL ;定义内存工作模式为小模式

.386;定义指令系统为80386指令集

.STACK ;定义1K个字节的堆栈段

.DATA ;数据段开始DATA1DD12340000H ;定义第一个32位数据的值为12340000HDATA2DD5678H ;定义第二个32位数据的值为5678HSUMDD? ;定义用来存放前两个数据之和的第三个数据

.CODE;代码段开始,数据段结束

.STARTUP ;程序开始

MOVEAX,DATA1 ;取第一个数到EAXADDEAX,DATA2 ;求和

MOVSUM,EAX ;保存结果(12345678H)至SUM.EXIT0 ;程序结束,正常返回到操作系统

END ;结束汇编2023/1/16三、保留字寄存器名、指令助记符、伪操作命令、表达式运算符,以及属性操作符等都是系统专用的保留字。这些保留字是不能用作标识符的。四、语句一条语句一般只占一行,超过一行时必须用续行符号“\”指示两条语句不能写在同一行。语句可以有注释,一般写在语句之后或单独占一行,是以“;”开始的字符串。2023/1/165.2汇编语言的数据和表达式汇编语言能识别的数据是常量、变量和标号。5.2.1常量常量是汇编时已经确定的值,主要用于伪指令中给变量赋值,或作为指令语句中的立即数或存储器操作数的组成部分。一.常量的类型数据形式格式×取值范围举例注释二进制数×…×B0~110010011B二进制数以B结尾八进制数×…×Q0~7123Q八进制数以Q结尾十进制数×…×D0~9256D,3458十进制数以D结尾或者缺省十六进制数×…×H0~9A~F0A3H,12345H十六进制数以H结尾,最前面必须是0~9字符或字符串'×…×'ASCII字符'ABC'两端必须加’或”2023/1/16二.符号定义伪指令

用于给程序中多次出现的同一个常量或表达式赋一个符号名,也可以为其它符号名取一个新名字,并赋给新的类型属性。(1)EQU伪指令例:FIRSTEQU1;定义常数

SECONDEQUFIRST*3+8;定义数值表达式

ADDR1EQUDS:[EBP+4];定义地址表达式

DWORDSEQUTHISDWORD;定义下面的字节变量为双字类型

BYTESDB10DUP(0)ADDR2EQUWORDPTRBYTES

;重新定义变量BYTES的名字和属性

START:MOVEAX,EBXGOONEQUFARPTRSTART

;重新定义标号START的名字和属性

COUNTEQUECX;为ECX重新取名注意:该等值语句只作为符号定义用,不产生任何目标代码,也不占用存储单元,并且不能是程序中曾经定义过的符号名。2023/1/165.2.2变量变量的值可以在程序运行过程中可随时修改,变量名是存放数据的存储单元符号地址,变量的值为对应存储单元的内容。一.变量的属性•段属性(SEG),指变量所在段的段基址。•偏移地址属性(OFFSET),指变量所在段中的偏移地址,即变量所在地址与段基址之间的字节距离。•类型属性(TYPE),指变量占用存储单元的字节数。若占用一个字节,称为字节变量,其类型为BYTE;若占用两个字节,称为字变量,其类型为WORD;若占用四个字节,称为双字变量,其类型为DWORD;若占用六字节,其类型为FWORD;若占用八字节,其类型为QWORD;若占用十字节,其类型为TBYTE。2023/1/16二.变量定义伪指令就是为数据分配存储单元,且对这个存储单元取一个名字,即变量名。语句的格式如下:[变量名]DB/DW/DD/DF/DQ/DT表达式1,表达式2,……变量名是可选的,DB/DW/DD/DF/DQ/DT是伪操作命令必须选用一种,表达式是赋给变量的初值,常见的有如下几种:(1)数值变量定义语句例:D_BYTEDB30H,40HDB50HD_WORDDW1234H,5678HD_DWORDDDD_DWORDD_TBYTEDT?D_FWORDDF1234567890ABHD_QWORDDQ1122334455667788H2023/1/16(2)字符串变量定义语句可以用DB来实现,即为串中的每一个字符分配一个字节存储单元。字符串必须用引号括起来,并且不超过256个字符,它们在内存中自左至右把字符的ASCII码按地址递增顺序依次存放。例:

STRING1DB'ABCDEFG'用DW也可以定义字符串变量,即给两个字符组成的字符串分配两个字节存储单元,它们在内存中的顺序是前一个字符为高字节,存放在高地址,后一个字符为低字节,存放在低地址。例:

STRING2DW'AB','CD','EF'2023/1/16三.内存定位和定义数制伪指令(1)ORG伪指令和当前位置计数器$汇编时将段名填入段表,同时为该段配备一个初值为0的位置计数器$。计数器依次累计段内语句被汇编后生成的目标代码字节个数。可用ORG伪指令把位置计数器$的值设置成需要的值。在数据段中,ORG后面的数据定义伪指令就从指定位置进行分配单元;在代码段中,ORG后面的一条指令语句就从指定位置生成目标代码;表达式的值应该是非负的整数。例:ORG0F0H;从0F0H开始安排数据

ORG$+10H;跳过10H个字节后安排数据

DW1,$+4,$+4

;100H单元的字值为1,102H单元的字值;为106H,104H单元的字值为108HARRAYDB12,34,56,5DUP(?);定义字节数组LENEQU$-ARRAY

;LEN的值为ARRAY变量所占的字节数82023/1/16(2)EVEN伪指令

用来把段内位置计数器的值置为偶数地址边界对齐,如果遇到EVEN时计数器$值非偶数,则汇编程序自动插入NOP指令(在代码段中),使其为偶数;或者将$的值加1(数据段中)。(3).RADIX伪指令宏汇编默认常量基数都是十进制数,可用.RADIX伪命令把缺省基数改为2~16范围内的任意基数:

.RADIX<表达式>

其中,表达式与当前基数无关,一定是十进制数。例:MOVAX,0FFHMOVBX,20.RADIX16MOVCX,0FFMOVDX,20D其中AX和CX寄存器的内容相同,BX和DX寄存器内容相同。2023/1/165.2.3标号标号之后必须有一个冒号(:),标号也可以单占一行。一.标号的属性

•段属性(SEG),指标号所在段的段基址。

•偏移地址属性(OFFSET),指标号所在段中的偏移地址,即标号所在地址与段基址之间的字节距离。

•距离属性或类型属性(TYPE),标号可作为转移和调用指令的目标地址,也可作为过程定义伪指令的过程名。当标号只允许作为段内转移或调用指令的目标地址时,距离属性为NEAR;当标号作为段间转移或调用指令的目标地址时,距离属性为FAR。例如:JMPLABEL1;程序跳转到标号LABEL1的位置CALLFARPTRSUBPROGRAM;调用SUBPROGRAM过程(FAR)LABEL1:┅;LABEL1为段内转移标号(距离属性缺省为NEAR)┅LABEL2:;LABEL2为段内转移标号,单独占一行┅SUBPROGRAMPROCFAR;SUBPROGRAM是属性为FAR的过程┅RET

标号的距离属性可用LABEL伪指令加以改变。2023/1/165.2.4表达式和运算符一、算术运算符包括+、-、*、/、MOD、SHL和SHR共七种;+、-、*、/参加运算的数和运算结果均为整数;除法运算为整除,而模除的运算结果为余数;左移或右移运算符可使二进制数左移或右移若干位,相当于二进制数进行乘法或除法运算。例:TEMP=10+5;TEMP=15TEMP=TEMP-3;TEMP=12TEMP=TEMP*5;TEMP=60TEMP=TEMP/9;TEMP=6TEMP=TEMPMOD4;TEMP=2TEMP=-TEMP;TEMP=-2MOVAL,11BSHL5;(AL)=01100000B注意:除了加和减运算符可以使用变量或标号外,其它算术运算符只适用于常量的数值运算。2023/1/16二、逻辑运算符有AND、OR、XOR、NOT共四种;只适用于对常量进行逻辑运算,运算是按位进行的;运算符与逻辑运算指令助记符相同,但在语句中的位置不一样,表达式中的逻辑运算符是在汇编时完成运算的;而逻辑运算指令运算在执行指令时进行。例:

MOVAL,NOT10100101B;(AL)=01011010BMOVAL,11011011BAND00001111B

;(AL)=00001011BMOVAL,11100001BOR10000101B

;(AL)=11100101BMOVAL,10111011BXOR00100100B

;(AL)=10011111B2023/1/16三、关系运算符

包括EQ、NE、LT、GT、LE、GE共六种;可对常量或同一段内的存储器地址进行比较运算;若条件满足,运算结果为真,输出结果为全“1”;若不满足条件,运算结果为假,输出结果为全“0”。例:

MOVBX,10EQ1010B

;10等于1010B为真,(BX)=0FFFFHMOVDX,20HGT32;20H大于32为假,(DX)=02023/1/16属性与返回数值的关系变量/标号属性返回数值

字节变量BYTE字变量WORD双字变量DWORD三字变量FWORD四字变量QWORD十字节变量TBYTE1246810标号NEAR标号FAR–1[FFH]–2[FEH]2023/1/164.LENGTHOF运算符该运算符加在变量名之前,返回的数值是变量中所定义的元素个数。

D1DW10HDUP(0),1234HD2DB20HDUP(2DUP(0),1)

D3DQ1234H,5678HD4DB‘ABCDEFGH’

D5DD12H,34H,\;加一个续行符,表示一条伪指令占两行

56H,78HD6DD12H,34H;未加续行符,则表示这两行是两条伪指令

DD56H,78HMOVAL,LENGTHOFD1;(AL)=11HMOVAL,LENGTHOFD2;(AL)=60HMOVAL,LENGTHOFD3;(AL)=2HMOVAL,LENGTHOFD4;(AL)=8HMOVAL,LENGTHOFD5;(AL)=4HMOVAL,LENGTHOFD6;(AL)=2H2023/1/165.SIZEOF运算符该运算符加在变量名之前,返回的数值是变量所占的总字节数,且等于LENGTHOF和TYPE两个运算符返回值的乘积。例如,对于上例中的变量,SIZEOF的返回值如下所示:MOVAL,SIZEOFD1;(AL)=22H,即20H*2HMOVAL,SIZEOFD2;(AL)=60H,即60H*1HMOVAL,SIZEOFD3;(AL)=10H,即8H*2HMOVAL,SIZEOFD4;(AL)=8H,即8H*1HMOVAL,SIZEOFD5;(AL)=10H,即4H*4HMOVAL,SIZEOFD6;(AL)=8H,即2H*4H2023/1/16五、修改属性运算符(1)PTR运算符格式:<类型>PTR<地址表达式>根据地址表达式的不同,所赋给的新类型可以是BYTE、WORD、DWORD、FWORD、QWORD、TBTYE、NEAR、FAR等,它们只在所在的指令内有效。例:TABLEDB1,2,3,4,5,6,7,8ADDWORDPTR[DI],100;指明目的操作数为字类型

JMPDWORDPTR[BX];指明为段间转移

MOVEAX,DWORDPTRTABLE;临时修改TABLE为双字类;型,(EAX)=04030201H(2)THIS运算符把它后面指定的类型或距离属性赋给当前的变量、标号或地址表达式,但不分配新的存储单元,往往与伪指令EQU或=连用,为当前存储单元定义一个指定类型的变量或标号,类型属性也可以是BYTE、WORD、DWORD、FWORD、QWORD、TBTYE、NEAR、FAR等。例:DATEQUTHISWORDPOINTEQUTHISFAR第一条语句将变量DAT的类型属性定义为字,不管DAT原来的类型是什么,从本语句开始,DAT成为字节变量;第二条语句将标号POINT的距离属性定义为FAR,不管POINT原来的距离属性是什么,从本语句开始,POINT成为远标号。2023/1/16六、其它运算符(1)高低分离运算符HIGH运算符和LOW运算符分别用于从16位运算对象中分离出高字节和低字节。从MASM6.0开始引入了HIGHWORD运算符和LOWWORD运算符分别用于从32位符号常量中分离出高字和低字部分。例:MOVAH,HIGH5678H;(AL)=56HDATA16EQU1234HMOVAL,LOWDATA16;(AL)=34HDATA32EQU1234FFFFHMOVAX,LOWWRODDATA32;(AX)=0FFFFH(2)方括号运算符:运算符中可以是数组变量的下标或地址表达式,以区别操作数和操作数地址。例:ARRAYDB1,2,3,4,5;ARRAY为数组变量

MOVAL,ARRAY[4]

;”4”为下标,(AL)=5MOVBX,OFFSETARRAY;(BX)=ARRAY的偏移地址

MOVAH,[BX];(AH)=1MOVDX,WORDPTRARRAY[1];(DX)=302H(3)运算符的优先级:一般可以用括号来改变运算符的优先级别。例:MOVAL,18OR5AND10;AL=18(12H)MOVAL,(18OR5)AND10;AL=22023/1/16运算符的优先级2023/1/16一、完整分段定义伪指令

1.段定义伪指令

SEGMENT/ENDS——将程序分成段:代码段,数据段,堆栈段,附加段。格式:段名SEGMENT[定位类型][组合属性][‘类别名’]…

(段体)

段名ENDS

功能:指出段名和段的各种属性,并表示段的开始和结束位置。段定义由伪操作SEGMENT开始、ENDS结束。其中:SEGMENT和ENDS必须成对出现,且语句前必须有段名,段名必须相同。

SEGMENT和ENDS语句之间可以有指令和其他伪指令,

表示存放在该段内存的变量、指令或其他伪指令对该段内存的处理程序中可以定义多个段。程序经汇编、连接及装入内存后,段名为一具体的段值。合法标识符,有段基地址和段内偏移量两个属性,与某个存储单元相联系。2023/1/16(1)定位类型——用于告诉链接程序,链接时(各模块.obj)

本段首地址的边界定位方式,常有四种:①PARA:段的起始地址必须是16的倍数(XXXX0H),这是一种默认方式。②PAGE:段的起始地址必须是256的倍数(XXX00H),

256字节为一页,在页的起点上。③WORD:段的起始地址必须是偶数(XX…0B)。④BYTE:段的起始地址可以是任何地址。(2)组合类型——

在多模块(每个模块有自己的代码段、数据段、堆栈段)组合时,告诉Link程序本段与其他模块中同名段的组合链接关系。2023/1/16①NONE:本段与其他同名段无组合关系,并有自己的段起始地址,这是一种默认方式。②PUBLIC:在满足定位类型的前提下,LINK程序将其与其他模块中的同名段邻接在一起,共用一个段地址。③STACK:同PUBLIC。链接以后作为堆栈段,并自动初始化

SS、SP。若程序中不说明STACK,则必须由用户在程序的开始处,自己通过语句设置SS、SP。④

COMMON:各模块中同名段重叠覆盖,有着相同的起始地址。段的长度取决于最长的COMMON段。段的内容为所链接的最后一个模块中COMMON段的内容。⑤

MEMERY:链接在其他所有段的后面(高端存储区)。若有多个MEMERY段,则只认第一个,其余按

COMMON处理。2023/1/16(3)段字属性在32位80X86微处理器中,新增加了USE属性说明。对于16位CPU默认的是16位段,即USE16。而对于汇编32位80X86CPU指令时,它默认采用32位段,即USE32。但可以使用USE16指定标准的16位段。若在程序开头使用了.386伪指令(见简化段定义伪指令),缺省类型为32位段字长。注意,在禁止用80386的情况下,使用USE选择项将导致出错。(4)段类别名属性类别名可以是任何合法的名字,必须用单引号括起来。在连接处理时,链接程序把类别名相同的所有段存放在连续的存储区内。典型的类别名如:‘DATA’,‘STACK’,‘CODE’。以上是定位类型、组合类型、段字和类别名四个参数的说明,各参数之间用空格分隔。在选用时,可以只选其中一个或两个参数项,但不能交换它们之间的顺序。2023/1/162.段寄存器说明伪指令

格式:ASSUME

段寄存器:段名[,段寄存器:段名,…]①设定特定的Sreg指向特点的段,说明源程序中定义的段应由哪一个Sreg去寻址。不如此,汇编程序无法生成目标代码程序。②ASSUME并未真正的将段地址装入相应的Sreg。Sreg的初值还必须由用户在程序的开始处用MOV指令来设置(CS除外)。(1)DS和ES的装入DS和ES的装入可以通过给寄存器赋初值的指令来完成。但是应注意到,由于段寄存器不能用立即数寻址方式直接传送,因此装入段基址必须借助于通用寄存器进行间接传送。例:CODESSEGMENTASSUMECS:CODES,DS:DATAS,SS:STACKS,ES:EXTRSSTART:MOVAX,DATASMOVDS,AXMOVAX,EXTRSMOVES,AX┅CSEGENDS2023/1/16(2)SS的装入一种方法是在SEGMENT语句中,组合类型选用STACK,并在ASSUME语句中,把堆栈用的段指派给段寄存器SS。

STACKSSEGMENTPARASTACKDB100HDUP(?)STACKSENDS┅CODESSEGMENTASSUMECS:CODES,SS:STACKS┅另一种方法是在SEGMENT语句中,组合类型未选用STACK参数,或者在程序中使用另一个堆栈段时,可采用类似于DS和ES的装入方法,用传送指令实现对SS的装入操作。(3)CS和IP的装入CS和IP的装入通常是按照结束伪指令指定的地址来自动完成的。结束伪指令的格式是:END[<起始地址>]起始地址是一个标号或地址表达式,这个地址是程序装入内存后的起始点,它的段基址和偏移量就是CS和IP的内容。2023/1/163.组定义伪指令GROUP格式:组名GROUP段名[,段名……]将程序中若干不同名的段集合成一个组,并赋予一个组名,使它们都装在一个64KB的物理段中,这时组内不同类型的段运行时共用一个Sreg,组内各段间的跳转都可以看作段内跳转。例:STACKSEGSEGMENTSTACK;定义堆栈段

DB256DUP(?)STACKSEGENDSDATA1SEGMENTWORDPUBLIC'CONST'CONS1DW100;定义数据段1DATA1ENDSDATA2SEGMENTWORDPUBLIC'VARS'VAR1DW?;定义数据段2DATA2ENDS2023/1/16DATAGROUPGROUPDATA1,DATA2

;组合两个数据段,以DATAGROUP为段组名CODESEGSEGMENTPARAPUBLIC'CODE';定义代码段

ASSUMECS:CODESEG,DS:DATAGROUP,SS:STACKSEGSTART:MOVAX,DATAGROUPMOVDS,AX;DS赋初值对该组寻址

MOVAX,CONS1;AX=100MOVVAR1,AX;VAR=100MOVAX,OFFSETVAR1;AX=2MOVAX,OFFSETDATA1

;AX=2(已分配2个字节内存单元)MOVAX,OFFSETDATA2

;AX=4(已分配4个字节内存单元)MOVAX,4C00HINT21H;DOS功能调用,可正常返回到操作系统CODESEGENDSENDSTART

;程序结束2023/1/16二、简化分段定义伪指令在MASM5.0版本以上的宏汇编语言中段的定义可以非常简单。.MODEL<存储模式>;定义程序的存储模式.STACK<长度>;定义堆栈段,长度缺省为1K字节.CODE[<名字>];定义代码段.DATA;定义数据段.DATA?;定义数据段,但初值不确定.FARDARA[<名字>];定义远调用数据段.FARDARA?[<名字>];定义远调用数据段,但初值不确定.CONST;定义只读常数数据段.STARTUP;程序起始点,并初始化DS、SS.EXIT0;程序结束点,返回到操作系统2023/1/16例:

.MODELSMALL;定义小型内存模式.386;可以汇编386指令.STACK100;定义堆栈段,长度为100字节.DATA;数据段开始XDD12345678HYDD87654321HZDD?,?.CODE;代码段开始.STARTUP;程序开始MOVEAX,XMULYMOVZ,EAXMOVZ+4,EDX.EXIT0;程序结束,返回,;相当于MOVAX,4C00H和INT21H两条指令END;汇编结束2023/1/161.定义内存模式伪指令

.MODEL存储模式[,语言类型][,操作系统类型][,堆栈类型](1)存储模式:①TINY:微型模式,程序中的数据和代码放在同一64K段内,这也就是后缀为.COM的程序。这种模式是MASM6才引入的。②SMALL:小型模式,程序中的代码放在64KB的数据段内,数据放在64KB代码的段内(包括数据段、堆栈段和附加段公用一个段),因而对代码和数据的访问可通过近程(NEAR)调用来实现。一般程序默认的都是该模式。③MEDIUM:中型模式,程序中的数据放在64KB的数据段内,代码量大于64KB,因而可安排在不同段内。这样,数据是近程的,而代码是远程的。④COMPACT:压缩模式,程序中的所有代码放在一个64KB的代码段内,而数据区可以大于64KB。这样,对代码的访问是近程的,而数据是远程的。⑤LARGE:大型模式,程序中的数据和代码均大于64KB,但静态(常数)数据限制在64KB之内。对程序和数据的访问默认都是远程的。⑥HUGE:巨型模式,程序中的数据和代码均大于64KB,静态数据也可以大于64KB。这样,对代码、数据和数组的访问都是远程的。⑦FLAT:平展模式,用于创建一个32位的程序,它只能运行在32位80X86CPU上。DOS下不能使用FLAT模式,而编写32位Windows程序时,必须采用FLAT模式。2023/1/16(2)语言类型:由它来告诉汇编程序将使用什么样的标识符的命名风格、子程序的调用和返回约定等。可使汇编语言程序与其它语言程序达到共享的目的。有效的语言类型为:C(C语言)、SYSCALL(系统调用)、STDCALL(标准调用)、Basic(Basic语言)、Fortran(Fortran语言)、Pascal(Pascal语言)等。(3)操作系统类型:OS_DOS是当前唯一支持的选项值,也是该选项的缺省值。(4)堆栈类型:堆栈类型的值主要影响伪指令.STARTUP所生成的指令序列。该选项有二个可选值:NEARSTACK和FARSTACK。其中:NEARSTACK是该选项的缺省堆栈类型。NEARSTACK——堆栈段和数据段是同一段;FARSTACK——堆栈段和数据段是不同的段,且堆栈不在段组DGROUP中。例:.MODELSMALL,C,OS_DOS,FARSTACK

2023/1/162.处理器选择伪指令.8086和.8087

可用来汇编8086/8088处理器和8087协处理器的指令,这是缺省模式。.286、.286C、.286P、.287可用来汇编286系列微处理器的指令。.386、.386C、.386P、.387可用来汇编386系列微处理器的指令。.NO87取消使用协处理器指令。.486、.486C、.486P可用来汇编486系列微处理器的指令。.586、.586C、.586P可用来汇编Pentium系列微处理器的指令。.686、.686P可用来汇编PentiumPro系列微处理器的指令。.MMX可用来汇编MMX指令。

.MMX和.686、.686P是MASM6.12引入的。.K3D可用来汇编AMD处理器的3D指令,是MASM6.13引入的。.XMM可用来汇编SSE指令和SSE2指令,是MASM6.15引入的。注意:80386以上处理器中,如果处理器选择伪指令放在.MODEL伪指令前面,那么段将定义成32位的段。如果希望处理器使用16位的段,则应在.MODEL伪指令后面使用处理器选择伪指令。2023/1/163.段名的缺省名使用简化的段定义伪指令时,每个段都有一个缺省名。在中内存模式和大内存模式时,.CODE伪指令表示的缺省段名为name_TEXT,即name是这个段名的可变部分,当程序模块有一个具体名字时,name就表示这个名字。.DATA、.CONST、.DATA?、.STACK定义的段内数据存放在一个叫DGROUP的段组中,各个段内的偏移地址均以这个起始地址为起点,而不依本段内的段地址为起点。.FARDATA或.FARDATA?伪指令使用的缺省名在各种模式下可以替换,它们定义的段内数据不放在任何段中,属于远程数据。内存模式段定义伪指令段名定位组合类别组名Small.CODE.DATA.CONST.DATA?.STACK_TEXT_DATACONST_BSSSTACKWORDWORDWORDWORDPARAPUBLICPUBLICPUBLICPUBLICSTACK'CODE''DATA''CONST''BSS''STACK'DGROUPDGROUPDGROUPDGROUP2023/1/164.等价名的使用MASM5.0中规定了几个等价名代替真实名。可以用@代替简化段定义伪指令前面的小数点。@CODE代表.CODE定义的段名;@FARDATA代表.FARDATA定义的段名;@DATA代表.DATA、.DATA?、.CONST和.STACK共享的组段名。例:ASSUMEES:@FARDATA;ES为远程数据段地址

MOVAX,@DATAMOVDS,AX;DS为DGROUP段组段地址

MOVAX,@FARDATAMOVES,AX5.段序定义伪指令MASM可以按照源程序中各个段出现的次序来排列目标文件中各段的先后次序,也可以按照段名的字母顺序来排列次序。缺省情况是按照段出现的次序来排列,可以定义段序:①.ALHPA:按照字母顺序对段排序。②.SEG:按照段出现的顺序对段排序。完整段定义格式中,默认按此顺序。③.DOSSEG:按照DOS定义的标准段序对段排序,顺序为:代码段、数据段、堆栈段。采用.MODEL伪指令的简化段定义格式默认按此顺序。2023/1/16三、使用简化段定义的程序框架(1)EXE标准程序框架汇编语言源程序经过汇编和连接后生成可执行文件(.exe)。操作系统为程序建立了一个程序段前缀区PSP,其长度为256个字节,主要用于存放用户程序的有关信息,如文件名、文件长度等。而在偏移100H处才装入程序本身。EXE程序加载要重新定位:1)DS和ES指向PSP段地址,而不是程序的数据段和附加段,所以需在程序中根据实际数据段改变DS和ES;2)CS:IP和SS:SP是由连接程序确定的值,指向程序的代码段和堆栈段。如果不指定堆栈段,则SS=PSP段地址,SP=100H,堆栈段占用PSP中的部分区域。2023/1/16例

.MODELSMALL;小内存模式

.586;可汇编并运行586指令

.STACK100H;256字节堆栈

.DATA

MSGDB'Welcome$';要写的信息

.CODE.STARTUP

MOVDX,OFFSETMSG;信息存储区首地址送DXMOVAH,9HINT21H;DOS写功能调用,在屏幕显示变量MSG内容'Welcome’.EXIT0;返回

END2023/1/16(2).COM格式的程序框架.COM程序是一种将代码、数据和堆栈段合一的结构紧凑的程序,所有的段都在一个逻辑段内,不超过64KB。在程序中采用.MODELTINY模式定义语句即可生成COM结构的程序。COM文件存储在磁盘上是主存的完全影像,不包含重新定位的加载信息,加载速度更快,占用的磁盘空间更少。COM程序加载后:1)所有段地址都指向PSP的段地址;2)程序执行起点是PSP后的第一条指令,既IP=100H;也就是说,COM程序的第一条指令必须是可执行指令,即程序的起始执行处是程序头。3)堆栈区设在段尾(通常为FFFEH),栈底的内容置为0000字。2023/1/16例子

.MODELTINY;采用微型模式.CODE;只有一个段,没有数据段和附加段.STARTUP;等效于ORG100H,汇编程序自动产生MOVDX,OFFSETSTRING1;显示提示信息MOVAH,9INT21HMOVAH,01H;等待按键INT21HMOVDX,OFFSETSTRING2;显示结束信息MOVAH,9INT21H.EXIT0STRING1DB'PRESSANYKEYTOCONTINUE!$'STRING2DB10,13,'PROGRAMRUNCOMPLETE!$'END2023/

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论