从C99标准开始,C语言支持可变参数宏(Variadic Macros)。可变参数宏允许宏接受不定数量的参数,类似于函数中的可变参数列表。定义可变参数宏时,需要使用省略号(...)来表示可变参数部分,并使用__VA_ARGS__来引用这些可变参数。 可变参数宏的基本语法如下: c #define 宏名(固定参数, ...) 替换文本(__VA_ARGS__...
在C语言中,可变参数函数依赖于两个宏定义:va_start、va_list、va_arg和va_end。这些宏定义定义在<stdarg.h>头文件中。它们的工作原理如下: va_list:定义一个类型为va_list的变量,用于保存可变参数列表的状态。 va_start:宏va_start初始化va_list变量,准备从可变参数列表的第一个参数开始处理。 va_arg:宏va...
C语言的宏文本替换,是通过预处理指令define实现的,#define的使用场景主要有:1)直接使用标识符不定义具体常量的标识符用法 2)替换常量的对象式宏(Object-like macros)3)模拟函数功能的函数式宏(Function-like macros)4)替换文中支持可变的参数数量的可变参宏 5)#和##运算法的用法等。define 标识符 当用...
1999 年的 ISO C 标准里规定了可变参数宏,语法和函数类似,比如: #define debug(format, ...) fprintf (stderr, format, __VA_ARGS__) 其中的“...”表示可变参数,实际调用时,它们会替代宏体里的__VA_ARGS__。GCC 支持更复杂的形式,可以给可变参数取个名字,如下所示。 #define debug(format, args.....
C:可变参数的宏 参考⾃:可变参数的宏:1. 可变参数的宏是C99规范开始⽀持的,具体⽤法如下:#define debug(…) printf(__VA_ARGS__)缺省号代表⼀个可以变化的参数表。使⽤保留名 __VA_ARGS__ 把参数传递给宏。当宏的调⽤展开时,实际的参数就传递给printf()了。如果缺省号之前有逗号,就要...
其实C99 标准已经支持了这个特性,但是其它的编译器不太给力,对 C99 标准的支持不是很好,只有 GNU C 支持这个功能,所以有时候我们也把这个可变参数宏看作是 GNU C 的一个语法扩展。 对于LOG 函数,如果我们想使用一个变参宏实现,就可以直接这样定义。
可变参数宏 #define __var_macro(...) __VA_ARGS__ 其中__VA_ARGS__替换...传入参包括参数之间的分隔符,如__var_macro(123,456)中的...=123,456 可变参数函数 可变参数函数形式如下void foo(int param1 , ...),使用可变参数函数的4个关键变量和宏是 ...
标识符中的...代表可变参数,args表示可变参数的名字,__LINE__是编译器内置的宏定义,表示当前行号。对于以上宏定义,如果我们传入的可变参数为空,会造成fprintf参数中多了一个逗号从而报错,为了解决这个问题,使用##表示如果可变参数为空,预处理器将去除掉它前面的那个逗号。
(1)不带参数名 (2)带参数名 第20行代码用 __VA_ARGS__来代表宏定义参数中的三个点(...),也就是可变参数。 再来说说“##”。如果调用:debug2("code = %d",100); 这样调用没有问题。 如果调用:debug2("hello"); 这里调用时,在format后面没有传入任何参数,那么就会编译错误,因为在宏替换之后变成了pr...
__VA_ARGS__宏是用来表示可变参数宏的可变参数的内容。简单的说就是将可变参数宏中的 ... 的内容原样传递给右边__VA_ARGS__所在的位置。示例代码如下: /*** @file test.c* @author Ailson Jack (jackailson@foxmail.com)* blog: www.only2fire.com* @brief* @version 1.0* @date 2021-10-29** @...