首页 > 代码库 > 关于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;
}

---------------------------------------------------------------

结果分析如下:

wKioL1N0I-aD0UX4AADQKhVONyQ838.jpg

在调用f之前,a的递增次数竟然取决于“它被拿来和谁比较”

C语言的灵活,会让你活的很幸福,同样也会让你死的很惨。

------------------------------------------------------------------------------------

本文出自 “_Liang_Happy_Life__Dream” 博客,请务必保留此出处http://liam2199.blog.51cto.com/2879872/1411510