在预处理器中拆分参数C++
Splitting arguments in C++ preprocessor
我正在处理的一些遗留代码有一个宏,它返回一个逗号分隔的列表,旨在用作函数参数。这很丑陋,但配置文件包含其中的许多内容,现在很难更改。
#define XY1 0,0
#define XY2 1,7
...
void fun_point(x,y);
fun_point(XY1);
只要它是正在调用的函数,就可以正常工作。但是,当尝试使用参数调用另一个宏时,整个字符串被视为一个参数,而不是在逗号处拆分为两个参数
#define MAC_POINT(x,y) (x+y)
MAC_POINT(XY1) #not expanded by preprocessor
是否有解决此问题而不更改 XY 定义?
有点
。以下作品:
#define MAC_POINT(x,y) (x+y)
#define MAC_POINT1(xy) MAC_POINT(xy)
#define XY x,y
MAC_POINT(x,y)
MAC_POINT1(XY)
但是,如果您只有一个参数,则必须从MAC_POINT更改为MAC_POINT1。
另一种可能性是:
#define MAC_POINT(x,y) (x+y)
#define MAC_POINT1(xy) MAC_POINT xy
#define XY x,y
MAC_POINT1((x,y))
MAC_POINT1((XY))
现在,您必须更改对宏的所有调用,但至少它们是一致的。
相关文章:
- 如何反转整数参数包
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 如何使用默认参数等选择模板专业化
- 模板参数替换失败,并且未完成隐式转换
- 具有默认模板参数的多态类的模板推导失败
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将数组作为参数传递给函数安全吗?作为第三方职能部门,可以探索他们想要的之外的其他元素
- 函数调用中参数的顺序重要吗
- 部分定义/别名模板模板参数
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- 使用不带参数的函数访问结构元素
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 如何在OMNET++中指定与命令行参数组合的输出文件名
- 如何使用Luacneneneba API正确读取字符串和表参数
- 在派生函数中指定void*参数
- 视图中的参数推导失败:take_while
- static_assert在宏中,但也可以扩展到可以用作函数参数的东西
- 使用指向成员的指针将成员函数作为参数传递
- 没有名称的C++模板参数
- 如何将enable-if与模板参数和参数包一起使用