函数调用时如何传递参数的约定
有三种方式:
- cdecl
- stdcall
- fastcall
1.cdecl(C中使用)
在这种方式中,调用者直接清理其压入栈的函数参数。在汇编中直接表现出来的就是在调用者函数代码段中ADD esp,8,将参数清除。
2.stdcall(常用于Win32 API,为了更好的兼容性)
由被调用者清理栈,若调用者给被调用者传入了两个4字节的参数(共8字节),则在被调用者函数结尾RETN 8来清理栈,RETN 8等同于(RETN + POP 8)除了恢复调用该函数之前的现场(即改变CS和IP的值)之外,还POP 8字节,清除参数。
3.fastcall
fastcall与stdcall方式基本类似,但该方式通常会使用寄存器(而不是使用栈内存)去传递那些需要传递给函数的部分参数(前两个)。若某函数有4个参数,则前两个参数分别使用ECX、EDX寄存器传递。
用寄存器传递参数肯定比栈内存快,这也是fastcall的优势,但是若函数太复杂,需要使用ECX、EDX作为其他用途,那也需要将参数存储到其他的地方。