阅读后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,因为它在海合会也是工作。标准中的定义在哪里,它来自何处?


当前回答

为什么这么复杂?

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

#include <stdio.h>

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

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

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

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

其他回答

xC++的反方向可以更快地达到零:

int x = 10;

while( 0 <---- x )
{
   printf("%d ", x);
}

8 6 4 2

你可以用箭来控制速度!

int x = 100;

while( 0 <-------------------- x )
{
   printf("%d ", x);
}

90 80 70 60 50 40 30 20 10

;)

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

-->不是操作员,事实上是两个独立的操作员,-->.

有条件的代码缩写x,而返回x原始值(未减少)值,然后将原始值与0使用>运算符 。

为了更好地了解,声明可以写成如下:

while( (x--) > 0 )

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

此外,它比"for (x = 10; x > 0; x --)"在一些平台上。

--是纯值后衰减运算符。

 while (x-- > 0) // x goes to 0
 {
     printf("%d ", x);
 }
  • 开始时,条件将评估为:(x > 0) // 10 > 0
  • 现在,由于条件是真实的, 它会随着价值的下降而进入循环x-- // x = 9
  • 这就是为什么第一个印刷价值是9
  • 等等,在最后的循环中x=1,因此条件是真实的。根据单词运算符,该值已改变为x = 0打印时。
  • 现在x = 0,用于评估条件(x > 0 )假的,时时循环出口。