- 論壇徽章:
- 0
|
看以下例子
實(shí)例1
- #define join(x,y) x ## y
- int join(join(join(x,y),z),0)()
- {
- cout << exec_op << endl;
- return 3;
- }
- int main(int argc, char *argv)
- {
- cout << xyz0() << endl;
- return 0;
- }
復(fù)制代碼
報(bào)錯(cuò),可能是由于編譯器只掃描一次源碼替換宏,所以報(bào)錯(cuò)。
而
實(shí)例2
- #define xjoin(x,y) x ## y
- #define join(x,y) xjoin(x,y)
- int join(join(join(x,y),z),0)()
- {
- return 3;
- }
- int main(int argc, char *argv)
- {
- cout << xyz0() << endl;
- return 0;
- }
復(fù)制代碼
則可以正常
也就是說,間接的定義這個(gè)連接宏,才可以多級(jí)嵌套使用,表面上看, #define join(x,y) 由于第一行已經(jīng)替換了,那跟實(shí)例1就是一樣了。為什么實(shí)例1會(huì)報(bào)錯(cuò),而實(shí)例2可以通過呢。 |
|