为什么调用者必须在cdecl调用约定中清除堆栈?

时间:2009-10-08 16:59:09

标签: c compiler-construction assembly stack calling-convention

来自:http://en.wikipedia.org/wiki/X86_calling_conventions

push c
push b
push a
call function_name
add esp, 12 ;Stack clearing
mov x, eax

为什么我们需要显式地将12添加到ESP以清除堆栈,因为被调用的函数应该将参数从堆栈中取出,因此恢复堆栈指针...?

另一个问题:

理论上,有可能实现变量参数函数,callee负责清理权限(例如,如果你在寄存器中传递堆栈中的参数数量)?

2 个答案:

答案 0 :(得分:19)

因为使用C调用约定,被调用函数将弹出参数。这就是这个召唤惯例的重点。

它允许变量参数之类的东西。

答案 1 :(得分:6)

就在_cdecl标题

上方的维基百科页面上
  

在这些约定中,调用者清除堆栈中的参数,这允许变量参数列表,例如。 printf()的