现在的位置: 首页 > 综合 > 正文

(译)win32asm教程-9

2013年11月08日 ⁄ 综合 ⁄ 共 1997字 ⁄ 字号 评论关闭
 

10.0 masm的优点

如果你不在使用masm,你可以跳过这章并尝试着转换所有的例子,或不论如何地读一下,并试着说服自己使用masm。当然,这是你的选择。但masm真的使汇编语言更容易了。

10.1 条件和循环结构

Masm有一些伪高阶的语法来简便地创建条件和循环结构:

.IF, .ELSE, .ELSEIF, .ENDIF
.REPEAT, .UNTIL
.WHILE, .ENDW, .BREAK
.CONTINUE

If

如果你有使用编程语言的经验(你应该有),你可能已经看到了一些像if/else的结构:

.IF eax==1
;eax
等于1
.ELSEIF eax=3
; eax
等于3
.ELSE
; eax
既不是1也不是3
.ENDIF

这种结构非常有用。你不需要和一对跳转搅在一起了,只要一个.IF语句(也不要忘记.IF.ELSE之前的时期)。嵌套的if是允许的:

.IF eax==1
.IF ecx!=2
; eax= 1
而且 ecx 不是 2
.ENDIF
.ENDIF

但可以更简洁些:

.IF (eax==1 && ecx!=2)
; eax = 1
而且 ecx 不是 2
.ENDIF

这些是你可以使用的操作符:

==

等于

!=

不等于

>

大于

<

小于

>=

大于等于

<=

小于等于

&

位测试

!

逻辑非

&&

逻辑与

||

逻辑或

CARRY?

carry bit set

OVERFLOW?

overflow bit set

PARITY?

parity bit set

SIGN?

sign bit set

ZERO?

zero bit set

Repeat

这个语句执行一块指令知道条件为真为止:

.REPEAT
;代码在此
.UNTIL eax==1

这块代码反复执行repeat和until之间的代码,知道eax=1。

While

While是repeat语句的反转。它在条件为真时执行代码块:

.WHILE eax==1
;代码在此
.ENDW

你可以使用.BREAK语句来跳出循环

.WHILE edx==1
inc eax
.IF eax==7
.BREAK
.ENDIF
.ENDW

如果Eax==7while循环将停止

continue指令使repeatWhile跳过下面的代码块,重新执行循环。

102 invoke

这是胜过tasmnasm最大的优点。Invoke简化了过程和call的使用。

一般的格式:

push parameter3
push parameter2
push parameter1
call procedure

Invoke 格式:

invoke procedure, parameter1, parameter2, parameter3

汇编后的代码是一摸一样的,但invoke格式更简单而且更可靠。对一个过程使用invoke,你要这样定义prototype:

PROTO STDCALL testproc:DWORD, :DWORD, :DWORD

声明了名为testproc,需三个DWORD大小的参数的过程。现在,如果你这么做……

invoke testproc, 1, 2, 3, 4

……masm会给你一个testproc过程需要三个参数而不是四个的错误。Masm还会做类型检查。它检查参数是否为正确的类型(即大小)

在一个invoke语句中,你可以用ADDR代替offset。这会使地址在汇编时是正确的。

过程这样定义:

testproc PROTO STDCALL :DWORD, :DWORD, :DWORD

.code

testproc proc param1:DWORD, param2:DWORD, param3:DWORD

ret
testproc endp

这会创建一个名为testproc,带三个参数的过程。Prototype是用来调用过程的。

testproc PROTO STDCALL :DWORD, :DWORD, :DWORD

.code

testproc proc param1:DWORD, param2:DWORD, param3:DWORD

mov ecx, param1
mov edx, param2
mov eax, param3
add edx, eax
mul eax, ecx

ret
testproc endp

现在,过程做了一下计算,(param1, param2, param3) = param1 * (param2 + param3).结果(返回值)存放在eax中,局部变量这样定义:

testproc proc param1:DWORD, param2:DWORD, param3:DWORD
LOCAL var1:DWORD
LOCAL var2:BYTE

mov ecx, param1
mov var2, cl
mov edx, param2
mov eax, param3
mov var1, eax
add edx, eax
mul eax, ecx
mov ebx, var1
.IF bl==var2
xor eax, eax
.ENDIF

ret
testproc endp

你不可以在过程外使用这些变量。它们储存在栈中而且当过程返回时移出。

10.3宏

现在不解释宏。可能在以后的教程中,但现在它们对我们不重要。

抱歉!评论已关闭.