.386
.model flat,stdcall
option casemap:none
.data
sum DWORD 0 ;创建一个全局变量,取名sum,初始化0
sum1 DWORD ? ;创建一个全局变量sum1,无初始化
;问号(?)初始化值使得变量未被初始化,这意味着在运行时才会为该变量分配一个值
;变量名其实是一个标号,标识了从该变量从所在段的开始到该变量的偏移量
list BYTE 10,20,30,40
BYTE 50,60,70,80
BYTE 81,82,83,84
;如果同一个数据定义中使用了多个初始化值,则它的标号只指出第一个初始化值的偏移量
;假设list的偏移量为0000,那么数值10的偏移量就为0000,20的偏移量为0001,30的偏移量为0002,40的偏移量为0003
;不是所有的数据定义都需要标号。比如, 要在list字节数组后面继续扩展,就可以在下一行定义后加的字节:
;BYTE 50, 60, 70, 80 BYTE 81, 82, 83, 84
ExitProcess PROTO,dwExitCode:DWORD
.code
main PROC
mov eax,5
mov sum,eax
INVOKE ExitProcess,0
main ENDP
END main
定义DWORD和SDWORD数据
.data
val1 DWORD 12345678h ;无符号数
val2 SDWORD -2147483648 ;有符号数
val3 DWORD 20 DUP(?) ;无符号数组
val4 DD 12345678h ;无符号数
val5 DD -2147483648 ;有符号数
pVal DWORD val3
;DWORD还可用于声明一种变量, 这种变量包含的是另一个变量的32位偏移量。如上所示, pval包含的就是val3的偏移量
myList DWORD 1, 2, 3, 4, 5 ;定义数组,偏移量的增量为4
定义压缩的BCD(TBYTE) 数据
Intel将一个压缩的BCD整数存放在一个10字节的包中。每个字节(除了最高字节外)包含两个十进制数字。在低9个字节中,每半个字节都存放了一个十进制数字。在最高字节中,最高位表示该数的符号。如果最高字节为80h,则该数为负数;如果最高字节为00h,则该数为正数。整数的范围是-999999999999999999到+999999999999999999。与其他数据值一样, BCD以小端序存储(最低字节存放在变量的起始偏移量处) 。
MASM使用T BYTE伪指令来声明压缩BCD变量。常量初始化值必须是十六进制的, 因为汇编器不会自动将十进制初始化值转换为BCD码。下面的两个例子展示了十进制数-1234有效和无效的表达方式:
定义浮点类型
.data
rVal1 REAL4 -1.2
rVal2 REAL8 3.2E-260
rVal3 REAL10 4.6E+4096
ShortArray REAL4 20 DUP(0.0)
;DD、DQ和DT伪指令也可以定义实数:
rVal4 DD -1.2 ;短实数
rVal5 DQ 3.2E-260 ;长实数
rVal6 DT 4.6E+4096 ;扩展精度实数
实例:变量相加程序
.386
.model flat,stdcall
option casemap:none
.data
firstval DWORD 20002000h
secondval DWORD 11111111h
thirdval DWORD 22222222h
sum DWORD 0
ExitProcess PROTO,dwExitCode:DWORD
.code
main PROC
mov eax,firstval
add eax,secondval
add eax,thirdval
mov sum,eax
INVOKE ExitProcess,0
main ENDP
END main
声明未初始化变量
.data?伪指令声明未初始化变量。当定义大量未初始化变量时, .data?伪指令减少了编译后程序的大小。例如,下述代码是高效率的声明:
.data? ;声明未初始化数据
bigArray DWORD 5000 DUP(?) ;20000个字节,未初始化