我读了关于宏的小gnu在线文档,对这句话有点困惑:
也可以通过标记粘贴形成多字符运算符,例如 +=
所以我徘徊如果宏可以执行复合赋值,如何?
#define PASTE(a,b) a##b
int foo;
foo PASTE(+,=) 2;
我唯一一次看到这很有用是在字节码解释器的内部循环中,它看起来像一个巨大的 case 语句,每个分支中都有非常重复的代码:
case OP_add: {
if (sp < 2) goto underflow;
double x = stack[--sp];
stack[sp-1] += x;
} break;
对每个支持的二元算术运算符重复此操作。通过标记粘贴功能,您可以从宏中生成它们:
#define ARITH_BINOP(name, oper) case OP_##name: { \
if (sp < 2) goto underflow; \
double x = stack[--sp]; \
stack[sp-1] oper##= x; \
} break /* deliberate absence of semicolon */
然后,在开关中,你可以写
ARITH_BINOP(add, +);
ARITH_BINOP(sub, -);
ARITH_BINOP(mul, *);
/* etc */
我认为,文档说明了以下情况:
#define COMPST(x, y) x ## y
int
foo(int x)
{
return x COMPST(+, =) 2;
}
当然,宏可以执行任何您可以在 C 代码中实现的功能:
#define INCREMENT(x) ((x) += 1)
main() {
int n=42;
INCREMENT(n);
}
你读到的那句话意味着我怀疑你不感兴趣的另一件事......