通过使用va_start宏我们可以取得可变参数表的首指针,这个宏的定义为: #define va_start (ap, v ) (ap= (va_list)&v+ _INTSIZEOF(v) ) 其作用为将最后那个固定参数的地址加上可变参数对其的偏移后赋值给ap,这样ap就是可变参数表的首地址。 _INTSIZEOF 宏定义为: #define _INTSIZEOF(n) ((sizeof(n...
变参宏的实现形式其实跟变参函数差不多:用… 表示变参列表,变参列表由不确定的参数组成,各个参数之间用逗号隔开。可变参数宏使用 C99 标准新增加的一个 VA_ARGS 预定义标识符来表示前面的变参列表,而不是像变参函数一样,使用 va_list、va_start、va_end 这些宏去解析变参列表。预处理器在将宏展开...
1999 年的 ISO C 标准里规定了可变参数宏,语法和函数类似,比如: #define debug(format, ...) fprintf (stderr, format, __VA_ARGS__) 其中的“...”表示可变参数,实际调用时,它们会替代宏体里的__VA_ARGS__。GCC 支持更复杂的形式,可以给可变参数取个名字,如下所示。 #define debug(format, args.....
C语言的宏文本替换,是通过预处理指令define实现的,#define的使用场景主要有:1)直接使用标识符不定义具体常量的标识符用法 2)替换常量的对象式宏(Object-like macros)3)模拟函数功能的函数式宏(Function-like macros)4)替换文中支持可变的参数数量的可变参宏 5)#和##运算法的用法等。define 标识符 当用...
大家都知道,printf函数就是通过可变参数机制来实现的。 可变参数可以这样定义和使用: (1)不带参数名 (2)带参数名 第20行代码用 __VA_ARGS__来代表宏定义参数中的三个点(...),也就是可变参数。 再来说说“##”。如果调用:debug2("code = %d",100); 这样调用没有问题。
这个可变参数的宏是新的C99规范中新增的,目前似乎只有gcc支持(VC6.0的编译器不支持)。 假如我们将上面的代码稍作一下修改,变成下面的样子。 #define OUTSCREEN(msg, ...) printf(msg, __VA_ARGS__) int main(int argc, char* argv[]) { ("Hello World!"); ...
可变(长)/不定(长)参数:函数可以接收任意数量的参数(函数在声名和定义时不明确参数的数量)C 的可变参数 参数列表 #va_list 4组宏 头文件 <stdarg.h> 宏 va_list:类型宏;参数列表 va_start():函数宏;va_list 指向参数列表的第一个参数 va_arg():函数宏;依据类型,va_list 指向参数列表的下一个参...
可变参数函数 可变参数函数形式如下void foo(int param1 , ...),使用可变参数函数的4个关键变量和宏是 <stdarg.h>va_listap;va_start(ap,param1);va_arg(ap,type);va_end(ap); 解释一下: va_list ap; 用于保存参数栈 va_start:通过最后一个确定的可变参数获得可变参数的内存栈 ...
在使用可变参数宏的过程中,我们不仅可以传多个参数,也可以传入0个参数,比如 debug("debug"); 然而当我们真的这样做的时候,编译器会报一个错误,原因是因为进行宏替换以后变成了如下的形式: printf("debug",); __VA_ARGS__会替换为与省略号匹配的所有参数,同时会将省略号前面的一个逗号带上,在如果不带任何参...