小智..
22
然而,如果你使用GCC,我发现了一个"技巧".
GCC在variadic宏上有一个方便的##扩展,允许你模拟一个默认参数.
技巧有局限性:它仅适用于1个默认值,参数必须是最后一个函数参数.
这是一个有效的例子.
#include
#define SUM(a,...) sum( a, (5, ##__VA_ARGS__) )
int sum (a, b)
int a;
int b;
{
return a + b;
}
main()
{
printf("%d\n", SUM( 3, 7 ) );
printf("%d\n", SUM( 3 ) );
}
在这种情况下,我将SUM定义为对sum的调用,默认的第二个参数为5.
如果使用2个参数(在主首先调用)调用,将它作为prepocessed:总和(3,(5,7));
这意味着:
第一个参数是3
第二个参数是序列(5,7)的结果......显然是7!
由于gcc很聪明,这对运行时没有影响,因为序列的第一个成员是常量而且不需要它,它将在编译时被丢弃.
如果只使用一个参数调用,gcc扩展名将删除VA_ARGS 和前导昏迷.所以它被预处理为:
sum(3,(5));
因此该程序给出了预期的输出:
10
8
所以,这并不完全模拟(与通常的宏观限制)功能以2个参数,最后一个是可选的,如果不提供应用的默认值.