C ++中的增量 - 帮助理解示例程序输出

时间:2014-01-19 01:20:20

标签: c++ integer

我目前正在学习C ++,我喜欢阅读和探索我在互联网上找到的程序。

我找到了这个示例C ++代码,它将“4大于2”作为输出,但我无法弄清楚原因:

#include <stdio.h>
#define MAX( a, b ) ( a > b ) ? (a) : (b)

int main()
{
    int x = 2, y = 2;

    if( MAX( ++x, y ) == x )
    {
        printf( " %d is greater than %d ", x, y );
    }

    return 0;
}

我不明白的是:如果你看一下陈述的段

if( MAX( ++x, y ) == x )

应该将X变量增加1,然后调用MAX;在那一点上,X应该是3.相反,当你编译它时,输出就像前面提到的那样。

我已经对++运算符的工作方式(Incrementing in C++)进行了一些研究,但无论如何我都无法得到解决方案。你能解释一下为什么会这样吗?

提前感谢您的帮助。

1 个答案:

答案 0 :(得分:5)

预处理器将您的条件扩展为

if( ( ++x > y ) ? (++x) : ((y) == x))

此增量x两次 - ++x > y相当于3>2,因此条件的计算结果为true,从而导致再次评估++x

另外,正如Benjamin Lindley指出的那样,如果你希望它在这种情况下返回最多两个值,你需要在宏周围加上额外的括号:

#define MAX( a, b ) (( a > b ) ? (a) : (b))