函数参数的计算次序是依赖编译器实现的,那么函数参数的入栈次序是如何确定的呢?strcpy(s, “D.T.Software”);调用约定当函数调用发生时参数会传递给被调用的函数而返回值会被返回给函数调用者调用约定描述参数如何传递到栈中以及栈的维护方式参数传递顺序调用栈清理调用约定是预定义的可理解为调用协议调用约定通常用于库调用和库开发的时候从右向左依次入栈: __stdcall, __cdecl, __thiscall从左向右依次入栈:__pascal, __fastcallc 语言编译器的默认调用预定, 从右向左依次入栈当程序中需要使用第三方库文件时,需要考虑调用约定是否一致例:主程序C语言编写,C语言编译器编译,默认从右向左的入栈顺序;库文件pascal语言编写,pascal语言编译器编译,默认从左向右的入栈顺序;当 C 主程序调用 pascal 语言完成的库文件时,C 主程序中需要显示的声明调用约定。可变参数C语言中可以定义参数可变的函数参数可变函数的实现依赖于 stdarg.h 头文件va_list - 参数集合va_arg - 取具体参数值va_start - 标识参数访问的开始va_end - 标识参数访问的结束实例分析: 编写函数计算平均值#include <stdio.h>#include <stdarg.h>float average(int n, …){ va_list args; int i = 0; float sum = 0; va_start(args, n); for(i=0; i<n; i++) { sum += va_arg(args, int); } va_end(args); return sum / n;}int main(){ printf("%f\n", average(5, 1, 2, 3, 4, 5)); printf("%f\n", average(4, 1, 2, 3, 4)); return 0;}输出:3.0000002.500000可变参数的限制可变参数必须从头到尾按照顺序逐个访问参数列表中至少存在一个确定的命名参数可变参数函数无法确定实际存在的参数的数量可变参数函数无法确定参数的实际类型注意:va_arg 中如果指定了错误的类型,那么结果是不可预测的。小结调用约定指定了函数参数的入栈顺序以及栈的清理方式可变参数是 C 语言提供的一种函数设计技巧可变参数的函数提供了一种更方便的函数调用方式可变参数必须顺序的访问,无法直接访问中间的参数值以上内容参考狄泰软件学院系列课程,请大家保护原创!