阅读后C++/STL 的隐藏特征和暗角上 年 月comp.lang.c++.moderated我感到非常惊讶的是, 以下的片段在2008年视觉工作室和G++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,因为它在海合会也是工作。标准中的定义在哪里,它来自何处?


当前回答

我读到的一本书(我记不清哪本书)写道:编译器试图将表达式解析为最大符号使用左右规则。

在这种情况下,表述如下:

x-->0

解析至最大符号 :

token 1: x
token 2: --
token 3: >
token 4: 0
conclude: x-- > 0

同一规则适用于此表达式:

a-----b

分析后 :

token 1: a
token 2: --
token 3: --
token 4: -
token 5: b
conclude: (a--)-- - b

其他回答

此代码首先比较 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

为什么这么复杂?

对最初问题的简单答案是:

#include <stdio.h>

int main()
{
    int x = 10;
    while (x > 0)
    {
        printf("%d ", x);
        x = x-1;
    }
}

我并不是说你们应该这样做,但是它也这样做,而且会用一个文章回答问题。

缩略x--以上所述,只是一个直截了当的速记,>只是普通的比普通的要大operator没有大谜!

) 太多人让简单的事情变得复杂,

(x --> 0)中指(x-- > 0).

  1. 您可以使用(x -->)
    Output: 9 8 7 6 5 4 3 2 1 0
  1. 您可以使用(-- x > 0)意思是(--x > 0)
    Output: 9 8 7 6 5 4 3 2 1
  1. 您可以使用
(--\
    \
     x > 0)

Output: 9 8 7 6 5 4 3 2 1

  1. 您可以使用
(\
  \
   x --> 0)

Output: 9 8 7 6 5 4 3 2 1 0

  1. 您可以使用
(\
  \
   x --> 0
          \
           \
            )

Output: 9 8 7 6 5 4 3 2 1 0

  1. 您也可以使用
(
 x 
  --> 
      0
       )

Output: 9 8 7 6 5 4 3 2 1 0

同样,您也可以尝试很多方法来成功执行此命令 。

使用-->降幅曾经(而且在某些情况下仍然)比x86结构的递增速度快。-->建议x将会0,并吸引有数学背景的人。

C和C+++和C++ 遵循“ 最大食量” 规则。同样的方式a---b翻译为(a--) - b,在您的情况中x-->0翻译为(x--)>0.

规则的基本内容是左向右, 表达式通过使用最大字符组成, 从而形成一个有效的符号 。