我有一个宏在GCC中运行得很好,但在微软的C++编译器中却不行。我希望有人可以知道解决方法,或者能够解释为什么会出现这种情况。
我确定这个宏不完全符合“标准”,但它真的可以帮助我。
这里是宏的功能示例:
#define VA_NARGS_IMPL(_1, _2, _3, _4, _5, N, ...) N
#define VA_NARGS(...) VA_NARGS_IMPL(__VA_ARGS__, 5, 4, 3, 2, 1)
#define FULLY_EXPANDED(count, ...) \
MAC ## count (__VA_ARGS__)
#define SEMI_EXPANDED(count, ...) FULLY_EXPANDED(count, __VA_ARGS__)
#define EXPAND_THESE(...) SEMI_EXPANDED(VA_NARGS(__VA_ARGS__), __VA_ARGS__)
#define ACTUAL_MACRO(x) parent->GetProperty<x>();
#define MAC1(a) ACTUAL_MACRO(a)
#define MAC2(a,b) MAC1(a) ACTUAL_MACRO(b)
#define MAC3(a,b,c) MAC2(a,b) ACTUAL_MACRO(c)
#define MAC4(a,b,c,d) MAC3(a,b,c) ACTUAL_MACRO(d)
#define MAC5(a,b,c,d,e) MAC4(a,b,c,d) ACTUAL_MACRO(e)
这是我可能会使用该宏的方式:
struct MyStructure
{
void Foo()
{
EXPAND_THESE(Property1, Property2, Property3, Property4)
}
Base * parent;
}
以下是GCC如何扩展上述内容:
struct MyStructure
{
void Foo()
{
parent->GetProperty<Property1>();
parent->GetProperty<Property2>();
parent->GetProperty<Property3>();
parent->GetProperty<Property4>();
}
Base * parent;
}
但是出于某些原因,Microsoft会将我所有的__VA_ARGS__扩展为一个参数:
struct MyStructure
{
void Foo()
{
parent->GetProperty<Property1, Property2, Property3, Property4>();
}
Base * parent;
}
有人知道为什么会这样吗?有没有什么诀窍可以让微软像GCC一样扩展它?也许再加入几对额外的括号?
类似这样的宏可能真的可以帮助我替换一堆“粘合”代码,但由于这个问题,我无法将其移到我的VS项目中。任何帮助都将不胜感激!
谢谢。