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

Flo*_*ora 0 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;
}
Run Code Online (Sandbox Code Playgroud)

我不明白的是:如果你看一下哪个段

if( MAX( ++x, y ) == x )
Run Code Online (Sandbox Code Playgroud)

它应该将X变量增加1,然后调用MAX; 在那一点上X应该是3.相反,当你编译它时,输出如前所述.

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

在此先感谢您的帮助.

sim*_*onc 5

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

if( ( ++x > y ) ? (++x) : ((y) == x))
Run Code Online (Sandbox Code Playgroud)

这增加x两次 - ++x > y相当于3>2条件评估为真,从而++x再次进行评估.

此外,正如Benjamin Lindley所指出的,如果您希望在这种情况下返回最多两个值,则需要在宏周围添加额外的括号:

#define MAX( a, b ) (( a > b ) ? (a) : (b))
Run Code Online (Sandbox Code Playgroud)

  • 这就是为什么`std :: max()`及其所有朋友[明确注意参数只被评估一次](http://stackoverflow.com/questions/3665574/only-one-evaluation-guaranteed-for -stdmin-stdmax). (2认同)