3

我无法正确获取此宏扩展

#define foo Hello
#ifdef foo
#define wrapper(x) foo ## x
#else
#define wrapper(x) boo ## x
#endif

调用:

wrapper(_world)

我想要的结果

Hello_world

但是,宏将“foo”定义视为文字,因此给出

foo_world

有人可以指出我的错误吗?

谢谢

4

1 回答 1

7

我会推荐gnu-cpp-manual它清楚地解释了宏是如何扩展的。

宏参数在被替换到宏体之前是完全宏扩展的,除非它们(宏参数)被字符串化或与其他标记一起粘贴(通过直接应用于的宏函数)。

例如:

如果参数被字符串化或连接,则不会发生预扫描。

#define AFTERX(x) X_ ## x
#define XAFTERX(x) AFTERX(x)
#define TABLESIZE 1024
#define BUFSIZE TABLESIZE

AFTERX(BUFSIZE) => X_BUFSIZE: 因为AFTERX是将参数与前缀连接起来,所以它的参数没有展开,剩下的BUFSIZE.

XAFTERX(BUFSIZE) => X_1024:XAFTERX不直接做串联,所以BUFSIZE会先展开。

通常,参数被扫描两次以扩展在它们中调用的宏。

- - 编辑 - -

所以更好的做法是:(代码来自QEMU源代码)

#ifndef glue
#define xglue(x, y) x ## y
#define glue(x, y) xglue(x, y)
#define stringify(s) tostring(s)
#define tostring(s) #s
#endif

glue(x,y)将连接x并且y两者都已经扩展。

于 2013-06-25T17:00:26.200 回答