我有以下宏:
#define GTR(type) \
type type##_gtr(type a, type b) \
{ \
return a > b ? a : b;\
}
我了解它会生成函数,但如果GTR(unsigned int)
扩展到main()
之外,我该如何调用生成的函数? _gtr(a, b)
不起作用......
答案 0 :(得分:4)
您必须编写unsigned int_gtr(a,b)
,因此对于使用您创建的宏定义的类型,它不起作用。
原因是预处理器只是替换type
参数并将其连接到##之后的文本。
你可以做一些事情,比如为unisgned int创建一个typedef所以没有空格然后使用它,例如:
typedef unsigned int uint;
GTR(uint)
...
uint_gtr(a,b)
答案 1 :(得分:3)
此:
type##_gtr
宏内部的将type
参数的值与文本_gtr
粘合在一起。这发生在返回类型和参数列表的左括号之间,即这形成了函数的名称。
因此,如果您使用GTR(unsigned int)
,则会失败,因为完整的函数原型最终看起来像这样:
unsigned int unsigned int_gtr(unsigned int a, unsigned int b)
这在语法上是不正确的。基本上,宏有一个弱点,因为它假定类型名称不能包含空格,这在C中是不正确的。
但是,如果您使用GTR(unsigned)
,则应将其称为unsigned_gtr()
。
答案 2 :(得分:3)
GTR(unsigned)
将扩展为:
unsigned unsigned_gtr(unsigned a, unsigned b)
{
return a > b ? a : b;
}
在这种情况下,您应该致电unsigned_gtr(a, b)
。
GTR(unsigned int)
会因语法错误而失败,因为您有两个单独的标记,并且无法正确生成函数的名称。