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


当前回答

--衰减操作员和操作员>大于运算符 。

两个操作员是作为一个单一操作员来操作的。-->.

其他回答

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

这是

#include <stdio.h>

int main(void) {
  int x = 10;
  while (x-- > 0) { // x goes to 0
    printf("%d ", x);
  }
  return 0;
}

空间让事情变得有趣--和 年 年 年 年 和 年 年>比较。

您使用的操作员称为“ 降级和时测试 ” 。 C99 标准对它的定义是 C99 标准,这是 C 编程语言标准的最新版本。 C99 标准在 C 语言中增加了一些新的操作员, 包括“ 降级和时测试” 操作员。 许多 C++ 编译员将这些新的操作员作为 C++ 语言的扩展。

以下是没有使用“降级和测试”操作员的代码:

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

在本版本的代码中,while循环使用>操作器来测试是否x大于 0。x--用于衰减的语句x乘以 1 ,在循环的每迭代结尾处。

为什么这么复杂?

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

#include <stdio.h>

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

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

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

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

这个-->完全不是接线员,我们有一个这样的接线员->,但不喜欢-->。它只是错误地解释while(x-- >0)仅表示 x 拥有后衰减运算符,而此循环将运行到大于.

写这个代码的另一种简单方法就是while(x--)时时一旦出现假情况,循环就会停止, 这里只有一个案例, 也就是说,0。当 x 值降为.