在 masm32.inc 中有这样几个函数的声明:
byt2bin_ex PROTO :BYTE, :DWORD
wrd2bin_ex PROTO :WORD, :DWORD
dw2bin_ex PROTO :DWORD, :DWORD
dw2hex_ex PROTO :DWORD, :DWORD
bin2byte_ex PROTO :DWORD
byt2bin_ex: 从 Byte 数到二进制字符串
; Test19_1.asm
.386
.model flat, stdcall
include windows.inc
include kernel32.inc
include masm32.inc
include debug.inc
includelib kernel32.lib
includelib masm32.lib
includelib debug.lib
.data
szBin db 8 dup(0), 0 ;这是接收二进制字符串的缓冲区
bVal db 3
.code
main proc
;查看数字的二进制信息
invoke byt2bin_ex, 2, addr szBin
PrintString szBin ;00000010
;查看变量 bVal 的二进制信息
invoke byt2bin_ex, bVal, addr szBin
PrintString szBin ;00000011
;查看寄存器 al 的二进制信息
mov al, 0feh
invoke byt2bin_ex, al, addr szBin
PrintString szBin ;11111110
ret
main endp
end main
wrd2bin_ex: 从 Word 数到二进制字符串
; Test19_2.asm
.386
.model flat, stdcall
include windows.inc
include kernel32.inc
include masm32.inc
include debug.inc
includelib kernel32.lib
includelib masm32.lib
includelib debug.lib
.data
szBin db 16 dup(0), 0 ;这是接收二进制字符串的缓冲区
wVal dw 3
.code
main proc
;查看数字的二进制信息
invoke wrd2bin_ex, 2, addr szBin
PrintString szBin ;0000000000000010
;查看变量 wVal 的二进制信息
invoke wrd2bin_ex, wVal, addr szBin
PrintString szBin ;0000000000000011
;查看寄存器 ax 的二进制信息
mov ax, 0fffeh
invoke wrd2bin_ex, ax, addr szBin
PrintString szBin ;1111111111111110
ret
main endp
end main
dw2bin_ex: 从 DWord 数到二进制字符串
; Test19_3.asm
.386
.model flat, stdcall
include windows.inc
include kernel32.inc
include masm32.inc
include debug.inc
includelib kernel32.lib
includelib masm32.lib
includelib debug.lib
.data
szBin db 32 dup(0), 0 ;这是接收二进制字符串的缓冲区
dwVal dd 3
.code
main proc
;查看数字的二进制信息
invoke dw2bin_ex, 2, addr szBin
PrintString szBin ;00000000000000000000000000000010
;查看变量 dwVal 的二进制信息
invoke dw2bin_ex, dwVal, addr szBin
PrintString szBin ;00000000000000000000000000000011
;查看寄存器 eax 的二进制信息
mov eax, 0fffffffeh
invoke dw2bin_ex, eax, addr szBin
PrintString szBin ;11111111111111111111111111111110
ret
main endp
end main
dw2hex_ex: 从 DWord 数到十六进制字符串
; Test19_4.asm
.386
.model flat, stdcall
include windows.inc
include kernel32.inc
include masm32.inc
include debug.inc
includelib kernel32.lib
includelib masm32.lib
includelib debug.lib
.data
szHex db 8 dup(0), 0 ;这是接收十六进制字符串的缓冲区
dwVal dd 255
.code
main proc
;查看数字的十六进制信息
invoke dw2hex_ex, 16, addr szHex
PrintString szHex ;00000010
;查看变量 dwVal 的十六进制信息
invoke dw2hex_ex, dwVal, addr szHex
PrintString szHex ;000000FF
;查看寄存器 eax 的十六进制信息
mov eax, 2694881440
invoke dw2hex_ex, eax, addr szHex
PrintString szHex ;A0A0A0A0
ret
main endp
end main
bin2byte_ex: 从字符串(必须有 8 个 '0' 或 '1' 组成)到字节
; Test19_5.asm
.386
.model flat, stdcall
include windows.inc
include kernel32.inc
include masm32.inc
include debug.inc
includelib kernel32.lib
includelib masm32.lib
includelib debug.lib
.data
szTxt1 db '00000010', 0
szTxt2 db '01111011', 0
szTxt3 db '11111111', 0
.code
main proc
invoke bin2byte_ex, addr szTxt1
PrintDec eax ;2
invoke bin2byte_ex, addr szTxt2
PrintDec eax ;123
invoke bin2byte_ex, addr szTxt3
PrintDec eax ;255
ret
main endp
end main
学习查看二进制是为了看到 EFLAGS 中的二进制位的变化:
; Test19_6.asm
.386
.model flat, stdcall
include windows.inc
include kernel32.inc
include masm32.inc
include debug.inc
includelib kernel32.lib
includelib masm32.lib
includelib debug.lib
.data
szBin db 8 dup(?), 0
.code
main proc
lahf ;LAHF 指令是把 EFLAGS 寄存器的低字节读入 AH
invoke byt2bin_ex, ah, addr szBin
PrintString szBin ;01000110
ret
main endp
end main