使用模板进行宏扩展

Cav*_*vaz 5 c++ macros templates

我正在编写几个函数,它们将模板函数的结果作为输入:

int alg1(Vect3) {...}
...
int algN(Vect3) {...}

void main() {
    alg1( mat.topRightCorner<3,1>() )
}
Run Code Online (Sandbox Code Playgroud)

如果您好奇,可以topRightCorner返回 的子矩阵mat,这是来自Eigen的方法,其中维度在编译时已知时作为模板参数放置。

然而,使用宏创建“快捷方式”以在不同算法之间快速切换(因为在实际代码中该函数被多次调用),如下所示

#define ALG(X)    ( algN(X) )

ALG( mat.topRightCorner<3,1>() )
Run Code Online (Sandbox Code Playgroud)

给出一个错误,因为宏被正确扩展但不知何故被误解为使用两个不同的参数,mat.topRightCorner<3并且1>().

用括号将输入包裹起来就可以了,但为什么会出现这种行为呢?

Lig*_*ica 5

因为,被预处理器接受为新宏参数的定界符,并且因为预处理器并不真正关心您可能将其作为模板参数列表的定界符。

稍微精确一点:

ALG( mat.topRightCorner<3,1>() )
     ^^^^^^^^^^^^^^^^^^^^ ^^^^
Run Code Online (Sandbox Code Playgroud)

这两个词法看起来都像有效的宏参数,宏解析优先。

另一方面,预处理器知道做什么(),因此您可以通过这种方式“强制”解析为单个参数。