为什么在vc6里面编写的程序都默认有个__cdecl,这是什么意思?

为什么在vc6里面编写的程序都默认有个__cdecl,这是什么意思?,第1张

给你copy了一个答案,这种问题一般用搜索引擎就能找到答案

_stdcall是Pascal程序的缺省调用方式,通常用于Win32 Api中,函数采用从右到左的压栈方式,自己在退出时清空堆栈。VC将函数编译后会在函数名前面加上下划线前缀,在函数名后加上"@"和参数的字节数。

C调用约定(即用__cdecl关键字说明)按从右至左的顺序压参数入栈,由调用者把参数d出栈。对于传送参数的内存栈是由调用者来维护的(正因为如此,实现可变参数的函数只能使用该调用约定)。另外,在函数名修饰约定方面也有所不同。

_cdecl是C和C++程序的缺省调用方式。每一个调用它的函数都包含清空堆栈的代码,所以产生的可执行文件大小会比调用_stdcall函数的大。函数采用从右到左的压栈方式。VC将函数编译后会在函数名前面加上下划线前缀。是MFC缺省调用约定。

_stdcall 和 __cdecl 都属于调用方式

一般我们在声明函数时都没有显示的说明调用方式,因为不同语言都有不同的默认调用方式

//********能否实现变参**********//

_stdcall

_stdcall是Pascal程序的缺省调用方式,通常用于Win32 Api中,由主调用函数采用从右到左的压栈方式进行参数压栈,然后由被调用者d栈(pop),被调用者自己在退出时清空堆栈。

_cdecl

C语言调用中默认的函数修饰_cdecl,由主调用函数进行参数压栈并且恢复堆栈。实参的压栈顺序是从右到左,最后由主调函数进行堆栈恢复(d栈)。由于主调用函数管理堆栈,所以可以实现变参函数。

/****************************/

_stdcall主调函数压栈,被调函数d栈,这样被调函数只能根据他的参数表进行d栈,所以没有办法实现变参

_cdecl主调函数压栈,主调函数d栈,压栈时已经知道有多个参数,这样可以实现变参

当然它们在汇编的层面 在函数命名的方式上有不同,这点我也不是很清楚,没有去涉及 可以自行去参考书籍


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/11570449.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-17
下一篇 2023-05-17

发表评论

登录后才能评论

评论列表(0条)

保存