共同点: 从右向左压栈实参.
压栈顺序: 1.压实参 2. 压EIP值 3.进入函数后, 压EBP值......
区别:
__cdecl 返回后ADD ESP, 4 (一个int参数)
__stdcall 返回前 RETN 04 (一个int参数)
__fastcall 如果只有两个参数,则不需要对ESP另作修改; 如果参数大于两个, 前两个参数仍然用EDX, ECX接收(ECX接收第一个参数), 剩余参数压栈. 返回时效仿__stdcall, RETN 04 (第三个参数是int). 举个例子:
//___例子____________________________________
int __fastcall add(int a, int b, int c, int d) //函数定义
{
return a+b+c+d;
}
add(1, 2, 3, 4); //函数调用
首先压栈4, 3
然后MOV EDX, 2 MOV ECX, 1
返回时只需 RETN 08
//___________________________________________
时间: 2024-12-05 00:17:51