来自于《Intel汇编语言程序设计》(第四版)的第八章。
让我们先来看看值传递,值传递相对简单,看以下代码:
.data
myData WORD 1000h ; this never changes
.code
main PROC
INVOKE Sub1, myData
exit
main ENDP
Sub1 PROC someData:WORD
mov someData,0
ret
Sub1 ENDP
程序使用 INVOKE 指令向Sub1传递参数myData的值,在最后的Sub1函数中虽然为someData赋了值,但是却并不影响myData的值。过于简单,不需要过多解释。
下面来看一下引用传递:
.data
myData WORD 1000h
.code
main PROC
INVOKE Sub2, ADDR myData ; pass by reference
exit
main ENDP
sub2 PROC dataPtr:PTR WORD
mov esi,dataPtr
mov WORD PTR[esi],0
ret
sub2 ENDP
可以看到在使用INVOKE调用Sub2时,将myData的地址传给了Sub2,而在Sub2中,参数是一个指向WORD的指针,Sub2接收了myData的地址之后,使用这个地址找实际上是在操作真正的myData,此时将0赋值给了myData,必然影响了myData中真正存储的值。
这便是高级语言中的传值和传址的汇编解释。
注意:在进行数据结构的传递时,一般采用引用传递的方式。