2

Boost.PP 序列限制为 256 个元素。为了解决这个问题,我想使用二维序列或序列序列,其定义如下:

((0)(1)(2)...(255))((256)(257))

现在,为了提供一个类似BOOST_PP_SEQ_FOR的算法,我想像这样嵌套其中两个:

//Inner loop
#define ELEM_ID_OP(_, func, elem) func(elem)
#define FOR_ELEM(func, seq) \
    BOOST_PP_SEQ_FOR_EACH(ELEM_ID_OP, func, seq)

//Outer loop
#define SEQ_ID_OP(_, func, seq) FOR_ELEM(func, seq) 
#define FOR_SEQ(func, multiseq) \
    BOOST_PP_SEQ_FOR_EACH(SEQ_ID_OP, func, multiseq)

//Testing function
#define MYFUNC(arg) \
    const int arg = 0;

FOR_ELEM(MYFUNC, (Zero)(One)(Two)) //works like a charm

FOR_SEQ(MYFUNC, ((zero)(one)(two))) //doesn't :(

在第二个问题上,我收到了多个关于未声明标识符的错误:

错误 C2065:“ELEM_ID_OP”:未声明的标识符
错误 C2065:“MYFUNC”:未声明的标识符
错误 C2065:“零”:未声明的标识符
错误 C2065:“一”:未声明的标识符
错误 C2065:“二”:未声明的标识符

这是否意味着我的编译器的最大递归深度已达到,因此宏ELEM_ID_OP不再MYFUNC扩展?或者 Boost.PP 中是否有一个实现细节阻止它工作?有解决方法吗?

如果有帮助,我正在使用 VC++2013。

4

1 回答 1

4

Boost.Preprocessor不能做嵌套SEQ_FOR_EACH。如果你使用了一个不错的预处理器,你可以使用 Chaos,它可以进行任意嵌套(尽管 a 不需要它,SEQ_FOR_EACH因为在 Chaos 中序列长度不受限制)。

对于如此简单的事情,您可以直接使用 VC++ 来完成,例如

#define CAT(a, ...) PRIMITIVE_CAT(a, __VA_ARGS__)
#define PRIMITIVE_CAT(a, ...) a ## __VA_ARGS__

#define A(id, value) const int id = value; B
#define B(id, value) const int id = value; A
#define A0
#define B0

#define C(bseq) CAT(A bseq, 0)

C(
    (zero, 0)
    (one, 1)
    (two, 2)
)

#undef A
#undef B
#undef A0
#undef B0
#undef C
于 2014-11-05T05:26:01.473 回答