《逆向工程核心原理》学习总结(三) - 函数调用约定

函数调用约定,决定在函数调用过程中参数的传递方式栈平衡由调用者还是被调用者执行返回值如何传递
三种比较基本的函数调用约定:

  • cdelc (C调用约定)
  • stdcall (标准调用约定)
  • fastcall (快速调用约定)

cdelc

参数通过堆栈传递,参数从右至左依次入栈;
调用者负责执行栈平衡;
返回值一般存放于eax中;

备注:cdelc是C语言默认的函数调用约定;函数名前面加下划线_;

stdcall

参数通过堆栈传递,参数从右至左依次入栈;
被调用者负责执行栈平衡(ret n指令),意味着更好的兼容性;
返回值一般存放于eax中;

备注:C函数前加关键字stdcall使函数调用约定变更;WINAPI 是 _stdcall的别称,意味着所有的Windows API函数都是stdcall调用约定;函数名前加下划线,函数名后加@。

fastcall

通过寄存器传参,速度更快。

前两个(最左边两个)参数通过ecx、edx传参,其他通过堆栈传参;
被调用者负责执行栈平衡;
返回值一般存放于eax中;

另外一种常见的函数调用约定 - thiscall

thiscall 是关于类的一种调用方式,不能被指定。
类函数调用相比于其他函数多了一个默认的this指针。
栈平衡维护与参数传递取决于参数的个数可变与否:

1) 参数从右向左入栈;
2) 如果参数个数确定,this指针通过ecx传递给被调用者;如果参数个数不确定,this指针在所有参数压栈后被压入堆栈;
3) 对参数个数不定的,调用者清理堆栈,否则函数自己清理堆栈。

你可能感兴趣的:(逆向工程,c语言,函数调用约定)