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

ano*_*non 6 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
Run Code Online (Sandbox Code Playgroud)

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

另一个问题:

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

sbi*_*sbi 19

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

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

  • 匿名:它不知道.它必须相信它(至少)在其声明中指定的参数数量被调用. (2认同)

syl*_*aar 6

它就在_cdecl标题上方的维基百科页面上

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