汇编语言

您所在的位置:网站首页 汇编语言add指令格式 汇编语言

汇编语言

2023-07-06 16:45| 来源: 网络整理| 查看: 265

汇编语言的指令格式,目前有两种不同的标准:Windows下的汇编语言基本上都遵循Intel风格的语法,比如:MASM、NASM;而Unix/Linux下的汇编语言基本上都遵循AT&T风格的语法;一、汇编语言语句的通用格式[名称[:]] 指令码 [第一操作数][,第二操作数] ;注释汇编语言的指令码的操作数的个数可以是0、1、2个;当操作数的个数为2的时候,语句还有两种不同的格式:Windows下Intel风格的汇编语言语句格式为:[名称[:]] 指令码 目的操作数DST,源操作数SRC ;注释Unix/Linux下AT&T风格的汇编语言语句格式为:[名称[:]] 指令码 源操作数SRC,目的操作数DST ;注释例如: CYCLE: ADD AX,02H ;(AX)BYTE变量名 DW 表达式 ;定义字变量,又称双字节变量(2个连续字节),DW-->WORD变量名 DD 表达式 ;定义双字变量,又称四字节变量(4个连续字节),DD-->DWORD变量名 DF 表达式 ;定义六字节变量,又称六字节变量(6个连续字节),DF-->FWORD变量名 DQ 表达式 ;定义长字变量,又称八字节变量(8个连续字节),DQ-->QWORD变量名 DT 表达式 ;定义十字节变量(10个连续字节),DT-->TBYTE;其中,变量名是一个合法的标识符,变量名后面不能加冒号":",只能用空格;变量名不是必要的,可有可无;变量的类型由关键字DB、DW、DD、DQ、DT来定义;变量定义语句中的"表达式"是用于对变量进行初始化的,可有一下几种情况:(1).一个或多个常数或表达式;当为多个常数或表达式时,期间要用逗号隔开;如DATA1--DATA4;(2).带单引号的字符串;对于字节型(DB)变量,每个变量的大小为1个字节,每个变量的值不能超过1个字符,每个字节内存入一个字符的ASCII码值,整个字符串可以在同一对单引号内给出,这相当于是定义了一个字符数组,如DATA5;对于字类型(DW)变量,每个变量的大小为2个字节,每个变量的值不能超过2个字符,若为2个字符时,同样遵循高位存入高字节,低位存入低字节的规则;若为1个字符,则该字符的ASCII码值存入到低字节,高字节为00,如DATA6;对于双字类型(DD)变量,每个变量的大小为4个字节,每个变量的值不能超过2个字符,若为2个字符,同样遵循高位存入高字节,低位存入低字节的规则;但是2个字符的值被存入到双字变量的最低2个字节中,1个字符的值被存入到双字变量的最低1个字节中;对于长字类型(DQ)变量,每个变量的大小为8个字节,每个变量的值不能超过2个字符,若为2个字符,同样遵循高位存入高字节,低位存入低字节的规则;但是2个字符的值被存入到长字变量的最低2个字节中,1个字符的值被存入到长字变量的最低1个字节中;(3).一个问号"?",表示该变量的值不确定,即:该变量所表示的内存单元中的内容是不确定的,或者说是,当表达式为问号时,变量所对应的内存区中并没有存入新的值,而只是预留出了相应的存储空间;如DATA7、DATA8(4).重复方式;此时的格式为: 重复次数 DUP(表达式);重复方式指出表达式的值可以重复地存储到变量对应的内存区中,重复的次数由伪指令给出,相当于定义数组;如DATA9、DATA10定义变量的例子:DATA1  DB 20H            ;1字节变量DATA2  DW 0204H,1000H    ;2字节变量DATA3  DB (-1*3),(15/3)  ;1字节变量DATA4  DD 123456H        ;4字节变量DATA5  DB '0123'         ;字符串变量,相当于一个字符数组DATA6  DW 'AB','C','D'   ;字符串变量,相当于一个字符串数组;DATA7  DB ?              ;1字节变量,未初始化DATA8  DD ?              ;4字节变量,未初始化DATA9  DB 5 DUP(0)       ;1字节变量,用5个0初始化,相当于是一个具有5个DB型元素的数组DATA10 DW 3 DUP(?)       ;2字节变量,未初始化,相当于是一个具有3个DW型元素的数组变量定义语句中伪指令的功能是在变量名所对应的地址开始的内存区依次存入表达式中的各项值,表达式中的每项值所占用内存字节数与变量的类型对应;总结:一个变量的变量名实际上就代表了该变量所对应的内存区在内存段中的有效地址(偏移地址);高地址是指地址值相对较大,低地址是指地址值相对较小,高地址与低地址是相对而言的;5、变量的属性:(1).属性介绍一个变量具有一下属性:A.段地址(SEG):变量所在段的段地址;B.偏移地址(OFFSET):变量所在段内的偏移地址;C.类型(TYPE):变量的类型定义了每个变量所占用的内存字节数,对于DB、DW、DD、DQ、DT类型定义的变量所占用的内存字节数分别是1、2、4、8、10;通常又将DB、DW、DD类型所定义的变量分别成为BYTE类型、WORD类型、DWORD类型变量;常用标识符的类型值列表:标识符种类  字节变量  字变量  双字变量  近标号NEAR  远标号FARTYPE的值     1          2        4          -1           -2D.长度(LENGTH):变量定义时,一个变量名所定义的变量个数;在含有DUP操作符的变量定义中,变量名所定义的变量个数为定义格式中的重复次数;在其它各种变量定义中,每个变量名所定义的变量个数均为1个;E.大小(SIZE):变量定义语句中,分配给同一个变量名的所有变量的总的字节数,其值为该变量的类型与长度的成绩;其中,段地址、偏移地址和类型属性是变量的主属性,而长度和大小属性是变量的辅助属性;(2).属性操作符:操作符    表达式              含义SEG        SEG 变量名或标号       取出变量名或标号所在段的段地址OFFSET     OFFSET 变量名或标号    取出变量名或标号所在段内的偏移地址TYPE       TYPE 变量名或标号      取出变量名或标号的类型(变量所占用的字节数)LENGTH     LENGTH 变量名          取出变量的长度SIZE       SIZE 变量名            取出变量的大小这些操作符不能单独构成语句,只能作为表达式的组成部分,并且表达式的求值也是在汇编过程中完成的;6.强制类型转换操作符PTR格式:数据类型 PTR 地址表达式格式中的"数据类型"可以是BYTE、WORD、DWORD、NEAR、FAR;前三种类型是变量的类型,后两种类型是标号的类型;格式中的表达式可以是变量、标号、其它地址表达式;PTR操作符的功能是用来重新定义已定义的变量或标号的类型,其作用域只在当前语句中; 例如:DATA1 DW 02HMOV BYTE PTR DATA1,AL这条指令中,是把DATA1的类型转换为BYTE类型,然后把AL中的内容存放到DATA1的最低一个字节中;作用域只在这条MOV语句中,过了这条语句,DATA1仍然是DW类型,即:DATA1原来的类型并没有被修改;7、复合数据类型:符合数据类型,除了用DUP定义的重复数据类型之外,与C/C++语言一样,汇编语言中也有结构体类型、联合类型、记录类型;(1).结构体类型:A.类型定义格式:结构类型名 STRUC [对齐类型Alignment][,NONUNIQUE]           Field1 Type1 Exp1           Field2 Type2 Exp2           ......           FieldN TypeN ExpN结构类型名 ENDS说明:结构体中的字段名可有可无;若有字段名,则字段名必须唯一,每个字段可独立存取;若没有字段名,则通过偏移量来存取;对齐方式Alignment:定义每个字段的字节对齐边界,对齐值有1、2、4、8、16字节对齐,值必须是2的幂次方;对齐类似于C/C++中结构体字段的对齐;NONUNIQUE:要求结构体中的字段必须用全名才能访问;结构体中的字段可以有字段名,也可以没有字段名;有字段名的字段可直接使用该字段名来访问,没有字段名的字段可用使用该字段在结构体中的偏移量来访问;例如:PERSON STRUC       NO   DD ?          ;有名字段,偏移量为0       NAME DB 10 DUP(?)  ;有名字段,偏移量为4            DB 1          ;无名字段,偏移量为14PERSON ENDSB.结构类型变量的定义:[变量名] 结构类型名 字段值列表中的各个字段之间用逗号","分割,字段值的排列顺序及类型应该与该结构定义时说明的各个字段相一致;如果结构变量中某个字段的值使用定义结构时说明的缺省值,那么可用逗号来表示;如果所有字段都使用定义结构体时说明的各个字段的缺省值,则可省去字段值列表,只需保留一对尖括号""即可;例如:Per1 PERSON              ;所有字段都是用默认值Per2 PERSON    ;所有字段都重新初始化Per3 PERSON       ;第二个字段使用默认值;C.结构体类型字段的引用:格式: 结构变量名.字段名这种引用方式与高级语言中的引用方式完全一致;另外,还可以使用偏移量来访问某个字段;方式1:使用字段名直接引用MOV AX,Per3.NAME方式2:使用字段的在结构体中的偏移量来引用LEA SI,Per3   ;取变量Per3对应内存块的有效地址MOV AX,[SI+4] ;寄存器相对寻址,4是字段NAME的偏移量(2).联合体类型:A.类型定义格式:[联合体类型名] UNION [对齐方式Alignment][,NONUNIQUE]           Field1 Type1 Exp1           Field2 Type2 Exp2           ......           FieldN TypeN ExpN[联合体类型名] ENDS说明:联合体类型中的各个字段相互覆盖,即:同样的存储单元被多个不同类型的字段所对应,并且每个字段在联合体类型中的偏移量都是0;联合体类型所占用的字节数是其所有字段所占字节数的最大值,即:联合体所占用的字节数是这个联合体的所有字段中占用字节数最多的那个字段占用的字节数;对齐方式Alignment:可用1、2、4、8、16个字节来指定联合体中各个字段字节的对齐边界,其缺省的对齐边界是1字节;还可用使用伪指令ALIGN或EVEN来重新定界,也可使用命令行选项/Zp来定界;NONUNIQUE:要求联合体类型中的字段必须使用全名才能访问;例如:DATE UNION     YEAR  DB 2010     MONTH DB 07     DAY   DB 04DATE ENDSB.联合体类型变量的定义:联合体类型的变量只能使用第一个字段的数据类型来进行初始化;例如:DATE1 DATE    ;定义一个联合体类型变量DATE1,并使用第一个字段的数据类型进行初始化DATE2 DATE  ;初始化错误,只能使用第一个字段的数据类型进行初始化;C.联合体类型字段的引用:格式: 联合体类型变量名.字段名例如:MOV DATE1.YEAR,2012  ;给联合体类型变量字段赋值MOV AL,DATE1.MONTH   ;AL=07MOV BX,DATE1.YEAR    ;BX=2012MOV DATE1.MONTH,08   ;月份置为8月(3).记录类型:A.类型定义格式:汇编语言中的记录类型与高级语言中的记录类型不同,在汇编语言中,记录类型是为按照二进制位存取数据提供方便的;记录类型的说明要用到另一个关键字RECORD,格式如下:记录名 RECORD 字段[,字段,...]其中,"字段"代表: 字段名:宽度[=初始值表达式]说明:记录名代表该记录类型;记录类型可以由多个字段组成,相邻两个字段之间用逗号隔开;记录类型中字段的属性包括字段名、宽度和初始值;记录类型中,字段的"宽度"属性表示该字段所占用的二进制位数,它必须是一个常数,并且所有字段的宽度之和不能大于16(即:WORD变量名 DD 表达式 ;定义双字变量,又称四字节变量(4个连续字节),DD-->DWORD变量名 DF 表达式 ;定义六字节变量,又称六字节变量(6个连续字节),DF-->FWORD变量名 DQ 表达式 ;定义长字变量,又称八字节变量(8个连续字节),DQ-->QWORD变量名 DT 表达式 ;定义十字节变量(10个连续字节),DT-->TBYTE;其中,变量名是一个合法的标识符,变量名后面不能加冒号":",只能用空格;变量名不是必要的,可有可无;变量的类型由关键字DB、DW、DD、DQ、DT来定义;变量定义语句中的"表达式"是用于对变量进行初始化的,可有一下几种情况:(1).一个或多个常数或表达式;当为多个常数或表达式时,期间要用逗号隔开;如DATA1--DATA4;(2).带单引号的字符串;对于字节型(DB)变量,每个变量的大小为1个字节,每个变量的值不能超过1个字符,每个字节内存入一个字符的ASCII码值,整个字符串可以在同一对单引号内给出,这相当于是定义了一个字符数组,如DATA5;对于字类型(DW)变量,每个变量的大小为2个字节,每个变量的值不能超过2个字符,若为2个字符时,同样遵循高位存入高字节,低位存入低字节的规则;若为1个字符,则该字符的ASCII码值存入到低字节,高字节为00,如DATA6;对于双字类型(DD)变量,每个变量的大小为4个字节,每个变量的值不能超过2个字符,若为2个字符,同样遵循高位存入高字节,低位存入低字节的规则;但是2个字符的值被存入到双字变量的最低2个字节中,1个字符的值被存入到双字变量的最低1个字节中;对于长字类型(DQ)变量,每个变量的大小为8个字节,每个变量的值不能超过2个字符,若为2个字符,同样遵循高位存入高字节,低位存入低字节的规则;但是2个字符的值被存入到长字变量的最低2个字节中,1个字符的值被存入到长字变量的最低1个字节中;(3).一个问号"?",表示该变量的值不确定,即:该变量所表示的内存单元中的内容是不确定的,或者说是,当表达式为问号时,变量所对应的内存区中并没有存入新的值,而只是预留出了相应的存储空间;如DATA7、DATA8(4).重复方式;此时的格式为: 重复次数 DUP(表达式);重复方式指出表达式的值可以重复地存储到变量对应的内存区中,重复的次数由伪指令给出,相当于定义数组;如DATA9、DATA10定义变量的例子:DATA1  DB 20H            ;1字节变量DATA2  DW 0204H,1000H    ;2字节变量DATA3  DB (-1*3),(15/3)  ;1字节变量DATA4  DD 123456H        ;4字节变量DATA5  DB '0123'         ;字符串变量,相当于一个字符数组DATA6  DW 'AB','C','D'   ;字符串变量,相当于一个字符串数组;DATA7  DB ?              ;1字节变量,未初始化DATA8  DD ?              ;4字节变量,未初始化DATA9  DB 5 DUP(0)       ;1字节变量,用5个0初始化,相当于是一个具有5个DB型元素的数组DATA10 DW 3 DUP(?)       ;2字节变量,未初始化,相当于是一个具有3个DW型元素的数组变量定义语句中伪指令的功能是在变量名所对应的地址开始的内存区依次存入表达式中的各项值,表达式中的每项值所占用内存字节数与变量的类型对应;总结:一个变量的变量名实际上就代表了该变量所对应的内存区在内存段中的有效地址(偏移地址);高地址是指地址值相对较大,低地址是指地址值相对较小,高地址与低地址是相对而言的;5、变量的属性:(1).属性介绍一个变量具有一下属性:A.段地址(SEG):变量所在段的段地址;B.偏移地址(OFFSET):变量所在段内的偏移地址;C.类型(TYPE):变量的类型定义了每个变量所占用的内存字节数,对于DB、DW、DD、DQ、DT类型定义的变量所占用的内存字节数分别是1、2、4、8、10;通常又将DB、DW、DD类型所定义的变量分别成为BYTE类型、WORD类型、DWORD类型变量;常用标识符的类型值列表:标识符种类  字节变量  字变量  双字变量  近标号NEAR  远标号FARTYPE的值     1          2        4          -1           -2D.长度(LENGTH):变量定义时,一个变量名所定义的变量个数;在含有DUP操作符的变量定义中,变量名所定义的变量个数为定义格式中的重复次数;在其它各种变量定义中,每个变量名所定义的变量个数均为1个;E.大小(SIZE):变量定义语句中,分配给同一个变量名的所有变量的总的字节数,其值为该变量的类型与长度的成绩;其中,段地址、偏移地址和类型属性是变量的主属性,而长度和大小属性是变量的辅助属性;(2).属性操作符:操作符    表达式              含义SEG        SEG 变量名或标号       取出变量名或标号所在段的段地址OFFSET     OFFSET 变量名或标号    取出变量名或标号所在段内的偏移地址TYPE       TYPE 变量名或标号      取出变量名或标号的类型(变量所占用的字节数)LENGTH     LENGTH 变量名          取出变量的长度SIZE       SIZE 变量名            取出变量的大小这些操作符不能单独构成语句,只能作为表达式的组成部分,并且表达式的求值也是在汇编过程中完成的;6.强制类型转换操作符PTR格式:数据类型 PTR 地址表达式格式中的"数据类型"可以是BYTE、WORD、DWORD、NEAR、FAR;前三种类型是变量的类型,后两种类型是标号的类型;格式中的表达式可以是变量、标号、其它地址表达式;PTR操作符的功能是用来重新定义已定义的变量或标号的类型,其作用域只在当前语句中; 例如:DATA1 DW 02HMOV BYTE PTR DATA1,AL这条指令中,是把DATA1的类型转换为BYTE类型,然后把AL中的内容存放到DATA1的最低一个字节中;作用域只在这条MOV语句中,过了这条语句,DATA1仍然是DW类型,即:DATA1原来的类型并没有被修改;7、复合数据类型:符合数据类型,除了用DUP定义的重复数据类型之外,与C/C++语言一样,汇编语言中也有结构体类型、联合类型、记录类型;(1).结构体类型:A.类型定义格式:结构类型名 STRUC [对齐类型Alignment][,NONUNIQUE]           Field1 Type1 Exp1           Field2 Type2 Exp2           ......           FieldN TypeN ExpN结构类型名 ENDS说明:结构体中的字段名可有可无;若有字段名,则字段名必须唯一,每个字段可独立存取;若没有字段名,则通过偏移量来存取;对齐方式Alignment:定义每个字段的字节对齐边界,对齐值有1、2、4、8、16字节对齐,值必须是2的幂次方;对齐类似于C/C++中结构体字段的对齐;NONUNIQUE:要求结构体中的字段必须用全名才能访问;结构体中的字段可以有字段名,也可以没有字段名;有字段名的字段可直接使用该字段名来访问,没有字段名的字段可用使用该字段在结构体中的偏移量来访问;例如:PERSON STRUC       NO   DD ?          ;有名字段,偏移量为0       NAME DB 10 DUP(?)  ;有名字段,偏移量为4            DB 1          ;无名字段,偏移量为14PERSON ENDSB.结构类型变量的定义:[变量名] 结构类型名 字段值列表中的各个字段之间用逗号","分割,字段值的排列顺序及类型应该与该结构定义时说明的各个字段相一致;如果结构变量中某个字段的值使用定义结构时说明的缺省值,那么可用逗号来表示;如果所有字段都使用定义结构体时说明的各个字段的缺省值,则可省去字段值列表,只需保留一对尖括号""即可;例如:Per1 PERSON              ;所有字段都是用默认值Per2 PERSON    ;所有字段都重新初始化Per3 PERSON       ;第二个字段使用默认值;C.结构体类型字段的引用:格式: 结构变量名.字段名这种引用方式与高级语言中的引用方式完全一致;另外,还可以使用偏移量来访问某个字段;方式1:使用字段名直接引用MOV AX,Per3.NAME方式2:使用字段的在结构体中的偏移量来引用LEA SI,Per3   ;取变量Per3对应内存块的有效地址MOV AX,[SI+4] ;寄存器相对寻址,4是字段NAME的偏移量(2).联合体类型:A.类型定义格式:[联合体类型名] UNION [对齐方式Alignment][,NONUNIQUE]           Field1 Type1 Exp1           Field2 Type2 Exp2           ......           FieldN TypeN ExpN[联合体类型名] ENDS说明:联合体类型中的各个字段相互覆盖,即:同样的存储单元被多个不同类型的字段所对应,并且每个字段在联合体类型中的偏移量都是0;联合体类型所占用的字节数是其所有字段所占字节数的最大值,即:联合体所占用的字节数是这个联合体的所有字段中占用字节数最多的那个字段占用的字节数;对齐方式Alignment:可用1、2、4、8、16个字节来指定联合体中各个字段字节的对齐边界,其缺省的对齐边界是1字节;还可用使用伪指令ALIGN或EVEN来重新定界,也可使用命令行选项/Zp来定界;NONUNIQUE:要求联合体类型中的字段必须使用全名才能访问;例如:DATE UNION     YEAR  DB 2010     MONTH DB 07     DAY   DB 04DATE ENDSB.联合体类型变量的定义:联合体类型的变量只能使用第一个字段的数据类型来进行初始化;例如:DATE1 DATE    ;定义一个联合体类型变量DATE1,并使用第一个字段的数据类型进行初始化DATE2 DATE  ;初始化错误,只能使用第一个字段的数据类型进行初始化;C.联合体类型字段的引用:格式: 联合体类型变量名.字段名例如:MOV DATE1.YEAR,2012  ;给联合体类型变量字段赋值MOV AL,DATE1.MONTH   ;AL=07MOV BX,DATE1.YEAR    ;BX=2012MOV DATE1.MONTH,08   ;月份置为8月(3).记录类型:A.类型定义格式:汇编语言中的记录类型与高级语言中的记录类型不同,在汇编语言中,记录类型是为按照二进制位存取数据提供方便的;记录类型的说明要用到另一个关键字RECORD,格式如下:记录名 RECORD 字段[,字段,...]其中,"字段"代表: 字段名:宽度[=初始值表达式]说明:记录名代表该记录类型;记录类型可以由多个字段组成,相邻两个字段之间用逗号隔开;记录类型中字段的属性包括字段名、宽度和初始值;记录类型中,字段的"宽度"属性表示该字段所占用的二进制位数,它必须是一个常数,并且所有字段的宽度之和不能大于16(即:



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3