在阅读了C++/STL的C++/STL的隐藏特征和暗角(comp.lang.c++.modated)之后,我感到非常惊讶的是,以下的片段在2008年视觉工作室和G++4.4编辑和工作。

代码如下:

#include <stdio.h>
int main()
{
    int x = 10;
    while (x --> 0) // x goes to 0
    {
        printf("%d ", x);
    }
}

产出:

9 8 7 6 5 4 3 2 1 0

我想这是C,因为它在海合会也是工作。标准中的定义在哪里,它来自何处?


当前回答

while( x-- > 0 )

这是如何解析的。

其他回答

此代码首先比较 x 和 0 , 然后比较 。 (第一个答案中也这么说 : 您是 后降 x , 然后将 x 和 0 与 > 运算符比较 。) 见此代码的输出 :

9 8 7 6 5 4 3 2 1 0

我们现在首先比较,然后通过在输出中看到 0 来减少。

如果我们想先消减然后比较, 使用这个代码:

#include <stdio.h>
int main(void)
{
    int x = 10;

    while( --x> 0 ) // x goes to 0
    {
        printf("%d ", x);
    }
    return 0;
}

产出是:

9 8 7 6 5 4 3 2 1

-- > 的用法具有历史意义。 衰落曾经( 在某些情况下现在仍然是) 比x86 结构的递增速度快。 使用 -- > 表示x 将达到 0, 并且吸引有数学背景的人 。

实际上, x 是在降序后, 条件正在检查中。 它不是 -- >, 而是 (x- -) > 0

注:在检查条件后, x 的值被更改,因为它在降序后发生。一些类似的情况也可能发生,例如:

-->    x-->0
++>    x++>0
-->=   x-->=0
++>=   x++>=0

总之,我们现在有一个"去"接线员。 " - - >"很容易被记住是一个方向, 而"当x去到零"的意思是直截了当的。

此外,它比某些平台上的“(x=10; x > 0; x-)”效率略高一些。

和这个完全一样

while (x--)