3

是否可以定义如下内容:

#define FOO(x, y) BAR()
#define FOO(x, sth, y) BAR(sth)

这样:

FOO("daf", sfdas);
FOO("fdsfs", something, 5);

翻译成这样:

BAR();
BAR(something);

?

编辑:实际上,BAR's 是我班级的方法。很抱歉之前没有这么说(认为这不相关)。

回答 DyP 的问题:

class Testy
{
    public:
    void TestFunction(std::string one, std::string two, std::string three)
    {
        std::cout << one << two << three;
    }
    void AnotherOne(std::string one)
    {
        std::cout << one;
    }
    void AnotherOne(void)
    {
        std::cout << "";
    }
};

#define PP_NARG(...) PP_NARG_(__VA_ARGS__,PP_RSEQ_N())
#define PP_NARG_(...) PP_ARG_N(__VA_ARGS__)
#define PP_ARG_N(_1, _2, _3, N, ...) N
#define PP_RSEQ_N() 3, 2, 1, 0

// macro for exactly 2 arguments
#define FOO_2(_1, _2) AnotherOne()
// macro for exactly 3 arguments
#define FOO_3(_1, _2, _3) AnotherOne(_2)

// macro selection by number of arguments
#define FOO_(N) FOO_##N
#define FOO_EVAL(N) FOO_(N)
#define TestFunction(...) FOO_EVAL(PP_NARG(__VA_ARGS__))(__VA_ARGS__)

并调用:

Testy testy;
testy.TestFunction("one", "two", "three");   // line 9

编译器输出:

警告 1 警告 C4003:宏 'PP_ARG_N' main.cpp 9 的实际参数不足

警告 2 警告 C4003:宏 'FOO_' main.cpp 9 的实际参数不足

错误 3 错误 C2039: 'FOO_' : 不是 'Testy' main.cpp 9 的成员

4

1 回答 1

10

编辑------------------------------------------------看这里 - - - - - - - - - - - - - - - - - - - - - - - - - ---------------->

在参数数量上重载宏

// functions, or macros, ....
void bar(){}
void bar(int){}

#define EXPAND(X) X    // for MSVC10 compatibility

// compute number of (variadic) macro arguments
// from http://groups.google.com/group/comp.std.c/browse_thread/thread/77ee8c8f92e4a3fb/346fc464319b1ee5?pli=1
#define PP_NARG(...) EXPAND( PP_NARG_(__VA_ARGS__, PP_RSEQ_N()) )
#define PP_NARG_(...) EXPAND( PP_ARG_N(__VA_ARGS__) )
#define PP_ARG_N(_1, _2, _3, N, ...) N
#define PP_RSEQ_N() 3, 2, 1, 0


// macro for exactly 2 arguments
#define FOO_2(_1, _2) bar()
// macro for exactly 3 arguments
#define FOO_3(_1, _2, _3) bar(_2)

// macro selection by number of arguments
#define FOO_(N) FOO_##N
#define FOO_EVAL(N) FOO_(N)
#define FOO(...) EXPAND( FOO_EVAL(EXPAND( PP_NARG(__VA_ARGS__) ))(__VA_ARGS__) )

int main()
{
    int something = 42;
    FOO("daf", sfdas);
    FOO("fdsfs", something, 5);
}

预处理器输出:

void bar(){}
void bar(int){}

int main()
{
    int something = 42;
    bar();
    bar(something);
}

Edit2:似乎 VS2010 在__VA_ARGS__宏替换方面存在一些问题。

更新:这是……一个错误??(另见这个问题):

#define MACRO2(PARAM0, PARAM1, ...) arg 0: >PARAM0<    arg 1: >PARAM1<    \
  additional args: >__VA_ARGS__<
#define MACRO1(...) MACRO2(__VA_ARGS__, OTHERARG_0, OTHERARG_1)

MACRO1(ARG0, ARG1);

预处理器输出:

arg 0: >ARG0, ARG1<    arg 1: >OTHERARG_0<    additional args: >OTHERARG_1<;

有关解决方法,请参阅链接的 SO 问题。我已经更新了上面的原始答案(代码)并使用 MSVC10 对其进行了测试-> 现在可以使用。

于 2013-05-04T14:58:42.717 回答