首页 > 代码库 > 关于C语言中#define的副作用讨论
关于C语言中#define的副作用讨论
MFC虽然没有未来,但是我觉得MFC的思想还是有必要研究研究的,在MFC中或者一些底层代码的编写中,宏是相当好用的,为什么呢?因为宏只是简单的替换,不进行类型转换,替换就意味着灵活,而C语言编程的灵魂就是灵活啊。
但是在高级语言中,甚至C++中,是提倡用const的,不提倡用#define,因为#define有一定的副作用,玩不好就没命了。
这里我们讨论下#define的副作用。
-------------------分割线哈----------------------
# include <stdio.h> # include <stdlib.h> # define CALL_WITH_MAX(a,b) f((a)>(b)?(a):(b)) int main(void) { int a = 5; int b = 0; CALL_WITH_MAX(++a,b); CALL_WITH_MAX(++a,b+20); return 0; }
------------------------------------------------
分析:
上面的问题,不知道大家有没有看出来。
对于CALL_WITH_MAX(++a,b);
1、a首先加1 ,变成了6
2、再和b进行比较,结果是a大,最后返回的结果是(++a),又被加1 ,最后的结果是7
对于CALL_WITH_MAX(++a,b+20);
1、a首先加1 ,变成了8
2、再和b进行比较,结果是a大,最后返回的结果是b,此时的b为20,那么a只加了一次,a的结果是8
---------------------------------------------------------
下面贴出完整代码:
# include <stdio.h> # include <stdlib.h> # define CALL_WITH_MAX(a,b) f((a) > (b) ? (a):(b)) void f(int x) { printf("compare result = %d\n",x); } int main(void) { int a = 5; int b = 0; printf("Initial value a = %d\n",a); CALL_WITH_MAX(++a,b); printf("excute the first a = %d\n\n",a); printf("Initial value a = %d\n",a); CALL_WITH_MAX(++a,b+20); printf("excute the second a = %d\n\n",a); return 0; }
---------------------------------------------------------------
结果分析如下:
在调用f之前,a的递增次数竟然取决于“它被拿来和谁比较”
C语言的灵活,会让你活的很幸福,同样也会让你死的很惨。
------------------------------------------------------------------------------------
本文出自 “_Liang_Happy_Life__Dream” 博客,请务必保留此出处http://liam2199.blog.51cto.com/2879872/1411510