04第四章 汇编语言程序设计01.ppt_第1页
04第四章 汇编语言程序设计01.ppt_第2页
04第四章 汇编语言程序设计01.ppt_第3页
04第四章 汇编语言程序设计01.ppt_第4页
04第四章 汇编语言程序设计01.ppt_第5页
已阅读5页,还剩37页未读 继续免费阅读

下载本文档

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

文档简介

第4章汇编语言与程序设计(1),主要内容:,汇编语言源程序的结构汇编语言语句格式伪指令功能调用汇编语言程序设计,4.1汇编语言源程序机器语言二进制数形式的指令和数据。B064是什么意思?这就是机器语言。既不直观,又不易理解和记忆.MOVAL,64H;很容易记忆理解,这就是助记符。助记符用便于记忆的英语单词表示的指令操作码。它反映了指令的功能和主要特征,便于人们理解和记忆。,操作数可能放在存储器中,这就涉及操作数的地址。程序中遇到转移指令或调用指令,也需要知道转移地址,若采用具体地址就很不方便,一旦有错,改动也很麻烦。于是人们采用标号或符号来代替地址,例:LP1:movax,VARloopLP1汇编语言指令助记符,符号地址,标号,伪指令等语言元素的集合以及这些元素使用的规则。用汇编语言编写的程序叫汇编语言源程序。,指令除了操作码以外,还有一个操作数问题。,汇编程序,源程序的编译程序,汇编程序,汇编语言源程序,机器语言目标程序,汇编源程序需翻译成机器语言,变成可执行文件,机器才能执行,这个翻译过程叫汇编。高级语言中称该过程为“解释”或“编译”。执行翻译的程序称为“汇编程序”。,汇编语言程序设计与执行过程,输入汇编语言源程序源文件.ASM汇编(编译)目标文件.OBJ链接可执行文件.EXE调试最终程序,4.1.1汇编语言源程序的结构,汇编语言源程序通常由一个或几个程序模块组成,每个模块一般由三个逻辑段组成:数据段存放数据、变量堆栈段堆栈区域代码段存放程序指令,一个基本的汇编语言程序框架如下:stackSEGMENTPARAstackDB100DUP(stack)stackENDSdataSEGMENTdataENDScodeSEGMENTASSUMECS:code,DS:data,ES:datastart:MOVAX,dataMOVDS,AXMOVES,AXMOVAL,4CHINT21HcodeENDSENDstart,堆栈段,数据段,代码段,4.1.2汇编语句格式,汇编语言的语句有两种:指令性语句由8086指令助记符构成的语句指示性语句由伪指令构成的语句(段定义、段对应等)宏指令语句由宏指令构成的语句指令性语句的格式为:标号:指令助记符目的操作数,源操作数;注释指示性语句的格式为:名字伪指令操作数1,操作数2,操作数n;注释宏指令语句的格式为:标号:宏指令操作数1,操作数2,操作数n;注释注:各部分之间至少要用一个空格作为分隔符。,指令性语句由CPU执行,每一条指令性语句都有一条机器码指令与其对应;指示性语句由汇编程序执行。它指出汇编程序应如何对源程序进行汇编,如何定义变量、分配存储单元以及指示程序开始和结束等。指示性语句无机器码指令与其相对应。指令性语句汇编时生成机器码;指示性语句汇编时不生成机器码。,语句的构成元素:标号指令的符号地址,用来代表指令在存储器中的地址。只能出现在指令性语句中,标号后应加上冒号。名字段、过程、变量的名字,用来代表它们在存储器中的地址。只能出现在指示性语句中,名字后不加冒号。指令助记符8086助记符、伪指令操作数即指令的操作对象对指令性语句0,1,2个对指示性语句根据需要而定操作数之间以逗号分隔操作数可以是:寄存器、存储单元、常数或表达式例如:AX,DI+BX+10,200,16*8+TABLE,等等,注释提高程序的可读性,以分号开头,可放在指令后,也可单独一行。注意注解的写法。要写指令(段)在程序中的作用,而不要写指令的操作。例如:以下为同一条指令写的注释1)MOVCX,100;传送100到CX2)MOVCX,100;循环计数器置初值显然,第二种写法要比第一种写法要好。,汇编语言的一个实例:hello.asmdataSEGMENTHelloDBHello,world!,0DH,0AH,$dataENDSprogSEGMENTASSUMECS:prog,DS:datastart:MOVAX,dataMOVDS,AXLEADX,hello;取字符串首地址MOVAH,9INT21H;显示字符串MOVAH,4CHINT21H;退回DOSprogENDSENDstart,名字,标号,4.1.3数据项与表达式,数据项包括常量、标号、变量及表达式。1.常量二进制数,以B结尾。如01001101B。十进制数,如85。十六进制数,以H结尾。第1个数字为A-F时,前面应加0,如0F160H。字符串:用引号括起来的1个或多个字符。如ERROR!,a,汇编时被翻译成对应的ASCII码45H,52H,52H,4FH,52H,21H和61H。,有三个属性:段地址:即标号所在段的段地址;偏移量:标号所代表存储单元的段内偏移地址;类型:NEAR或FAR:NEAR表示标号所在语句与转移指令/调用指令在同一码段内,跳转时只需改变IP即可。FAR标号所在语句与转移指令/调用指令不在同一代码段内。若没有对类型进行说明,默认为NEAR。标号通常作为转移指令或CALL指令的转移地址。,2.标号指令所在内存单元的符号地址,变量即内存中的存储单元或数据区。变量名是存储单元(数据区)的符号地址或名字。变量也有三个属性:段地址变量所在段的段地址偏移量变量单元地址与段首地址之间的位移量。类型有BYTE、WORD和DWORD三种。变量在程序中作为存储器操作数被引用。,3.变量,标号和变量名的使用规则组成:A-Z(不分大小写),0-9,?_$不能以数字开头,句号(.)只能作为首字符长度小于31个字符不能与保留字(指令助记符、伪指令、预定义符号等)重名不能重复定义例如:正确的:LP1,AGAIN,NEXT,_GO,OK_1错误的:4M,LOOP,AAA,#HELP,+ONE,4.表达式,表达式是常数、寄存器、标号、变量与运算符的组合。有数字表达式和地址表达式两种。汇编时按优先规则对表达式进行计算,计算出具体的数值或地址。运行时不能改变。表达式中的运算符有6类:算术、逻辑、关系、取地址、属性、杂类。,用于数字表达式,例:MOVAX,4*1024汇编后的形式为:MOVAX,4096用于地址表达式,例:LEASI,TAB+3若TAB的偏移地址为1000H,则汇编后的形式为:LEASI,1003H,1)算术运算符+、-、*、/,MOD,逻辑运算符只能用于数字表达式中。例:MOVCL,36HAND0FH经汇编后:MOVCL,06H注意,不要把逻辑运算符与逻辑运算指令混淆:例:ANDAX,3FC0HAND0FF00H汇编后源操作数被翻译为:3F00H,所以上述指令与ANDAX,3F00H等价。,2)逻辑(位)运算符AND、OR、XOR、NOT,GREAT,LITTLE,EQUAL,NOT的缩写关系运算的结果是一个逻辑值:真或假关系为真,结果为全1关系为假,结果为全0例:MOVBX,PORTGT300H若PORT的值大于300H,则汇编后为:MOVBX,0FFFFH否则汇编后为:MOVBX,0,3)关系运算符EQ、NE、LT、GT、LE、GE,SEG:取变量/标号的段地址OFFSET:取变量/标号的偏移地址例:VARDB12HMOVBX,OFFSETVAR;取变量VAR的偏移地址MOVAX,SEGVAR;取变量VAR的段地址注意,以下指令的异同:MOVBX,OFFSETVARLEABX,VAROFFSET只能取静态的偏移地址;LEA指令即可取静态的偏移地址,也可取动态的偏移地址。,4)分析运算符SEG、OFFSET,TYPE取变量的类型(1,2,4)LENGTH取所定义变量的长度(即变量中元素的个数)SIZE取所定义存储区的字节数(=TYPE*LENGTH)例:VARDW1,2,3,4,5则TYPEVAR=2LENGTHVAR=5SIZEVAR=10,5)取值运算符TYPE、LENGTH、SIZE,6)属性运算符PTR,用来指定地址操作数的类型。格式:PTR类型BYTE,WORD,DWORD,NEAR,FARBYTE、WORD、DWORD用于描述数据存储单元(变量)地址NEAR、FAR用于描述转移、调用的目的地址,例:MOVBYTEPTRDI,0;字节类型MOVWORDPTRDI,0;字类型MOVDI,0B5H;类型不定PTR并不分配存储单元,用来进行强制类型转换例:STR1DW?;STR1定义为字类型MOVAX,STR1;合法MOVAL,STR1;非法MOVAL,BYTEPTRSTR1;合法,4.2伪指令,数据定义伪指令符号定义伪指令段定义和段寄存器指定伪指令过程定义伪指令结束伪指令,由汇编程序执行的指令,它本身不被汇编成机器指令。常用的伪指令有:,4.2.1数据定义伪指令,用于定义变量,即内存单元或数据区。数据定义伪指令的格式为:变量名数据定义伪指令操作数,操作数,常用的数据定义伪指令有如下几种:DB定义字节DW定义字DD定义双字操作数可以是常数、变量或表达式,例1:DATA_BDB10,5,10HDATA_WDW100H,-4DATA_DDD0FFFBH汇编后的内存分配情况如右图所示。,05H,10H,00H,01H,FCH,FFH,FBH,FFH,00H,00H,0AH,Q,DATA_B,DATA_W,DATA_D,10,5,10H,100H,-4,0FFFBH,例2:操作数可以是字符串,例如STRDBHELLO汇编后的情况如图:,STR,H,E,L,L,O,注意下面两个定义的不同之处:DBAB;41H在低字节,42H在高字节DWAB;42H在低字节,41H在高字节,48H,45H,4CH,4CH,4FH,操作数?用来保留存储空间,但不存入数据.例3:ABCDB0,1,2,3,4,OK,$RSVDB?,?,?,?,?,?,?,?复制操作符DUP:重复的数据可以使用复制操作符DUP,如上面RSV亦可写成:RSVDW8DUP(?)若操作数中若使用$,则表示的是地址计数器的当前值(当前即将分配地址)。,汇编后内存分配情况,例:TABLEDB10DUP(?)BUFFERDWTABLE,$+3设TABLE的偏移地址为0080H,则汇编后如下图所示:,BUFFER,0080H,80H,TABLE,008AH008BH008CH008DH,.,8FH,00H,00H,0089H,10Bytes,4.2.2符号定义伪指令,把一个表达式用一个符号表示,以后凡出现该表达式的地方都可用这个符号表示。类似于C语言中的#define。符号定义伪指令有两种:EQU,=,用EQU定义的符号未清除前,不能重新定义。清除EQU定义可用PURGE伪指令。用”=”定义的符号可在任何时候进行重定义。二者均不占用存储空间,仅是给符号赋值,例:FIVEEQU5COUNTEQUCXTENEQU10DIST=BYTEPTRSI+BPGOTO=JMPMOVAX,TENMOVCX,COUNTADDDIST,FIVEDIST=WORDPTRSI+BP+1ADDDIST,AXGOTOLABEL,定义,引用,4.2.3段定义伪指令,汇编语言程序是按段来组织程序和数据的。和存储器的物理段相对应,汇编语言程序中的段称为逻辑段。汇编连接后被映射到物理段中。三类段:代码(程序)段、数据段、堆栈段段定义伪指令:SEGMENT、ENDS、ASSUME、ORG定义一个段的基本格式:段名SEGMENT定位类型组合方式类别段名ENDS,这两个伪指令总是成对出现,二者前面的段名应一致。SEGMENT说明了一个段的开始,ENDS说明了一个段的结束。对数据段和堆栈段,段中的语句一般是变量定义。对代码段则是指令语句。如:dataSEGMENTdataENDS,SEGMENT和ENDS伪指令,ASSUME伪指令,在代码段中,还必须明确段和段寄存器的关系,这由ASSUME语句来指定。如ASSUMECS:code,DS:data,ES:data语句中的code和data为段名。这个语句说明:1.CS将指向名字为code的代码段2.DS和ES将指向名字为data的数据段,但要注意,ASSUME伪指令只是告知汇编程序有关段寄存器与段的关系,并没有给段寄存器赋予实际的初值。故下面的语句MOVAX,DATAMOVDS,AXMOVES,AX将段基址装入段寄存器。如果程序中用到堆栈段,则SS也需装入实际的初值。代码段基地址不需要程序员装入CS寄存器,而由OS负责装入。,SEGMENT语句后可以带有可选参数,用以规定逻辑段的其他一些属性。,1)定位类型说明如何确定逻辑段的边界。有四种:PARA(Paragraph):逻辑段从一个节(16个字节)的边界开始。即段的起始地址应能被16整除,或这说段起始物理地址应为0H。默认类型BYTE:逻辑段从字节边界开始,即段可以从任何地址开始。WORD:逻辑段从字边界开始。即段的起始地址必须是偶数。PAGE:逻辑段从页边界开始。256字节称为一页,故段的起始物理地址应为00H。,2)组合类型说明不同模块中同名段的组合方式。PUBLIC:所有此类型的同名段组合成一个逻辑段,公用一个段地址,运行时装入同一个物理段中。COMMON:所有此类型的同名段具有相同的起始地址(覆盖),共享相同的存储区域。AT:按绝对地址定位,段地址就是表达式的

温馨提示

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

评论

0/150

提交评论