汇编语言源程序包括的语句类型为:指令性语句和指示性语句。
看一副图片:
(1)变量名 DB 一个或多个用逗号间隔的单字节数
例如:
N1 DB 12H,64,-1,3*3
DB 01010101B,'A','B'
DB 0A6H,'HELLO'
N2 DB ?,?,? ;与N2 DB 3 DUP(?)等价
说明:
DB:字节
?——随机数,DUP()——重复表示括号里面内容
如:3 Dup(?):代表3个用逗号隔开的随机数
5 Dup(‘A’):表示五个用逗号逗号隔开的A的ascall码值。
(2)内存中存储方式
注意:
1、此处N1变量名,定义的DB是依次存储内存中,无高低位之分,比如一个数值:1234H,他们存储的位置12H在上面,34H在下面,这个需要注意。
2、DB定义的8位的数值。
(1)格式:变量名 DW 一个或多个用逗号隔开的双字节数
例如:
WNUM DW 1234H,56,'AB','C'
DW ?,? ;DW 2 DUP(?)等价
说明:
1、DW——字定义
2、?——双字节随机数
3、单引号中只能是一个或两个字符(16位)
(2)内存中存储方式
格式: 变量名 DD 一串用逗号间隔的4字节数
例如: DNUM DD 12345678H
说明:
汇编程序对源程序是逐行汇编的,$ 运算符可以返回汇编计算器的当前值。
应用:$ 运算符紧跟在DB、DW、DD伪指令之后,统计字符串的长度。
例如:数据段有:
BUF DB'THE QUICK BROWN FOX' ;字符串长度19,空格也需要算在里面
LLL EQU $-BUF
汇编之后,LLL的值就为19.
格式:SEG段名或变量名或标号名
功能:计算某一逻辑段的段基址
例如:
MOV AX,SEG DATA
MOV DS,AX
设“DATA”是数据段的段名,上述两条指令算出数据段的段基址,先赋给AX,再转赋给DS。
格式:OFFSET 变量名或标号名
功能:算出逻辑段中某个变量或标号名所在单元相对于段首的偏移地址
例如:设以‘DATA’为段名的数据段,存在
BUF DB 12H,34H,56H
代码段:MOV AX,SEG DATA
MOV DS,AX
MOV BX,OFFSET BUF
MOV AL,[BX] ;间接寻址
格式:类型说明符 PTR 地址表达式
下面有两类,当类型确定时,既不需要用ptr来转换,否则就需要;