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


当前回答

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

 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 )假的,时时循环出口。

其他回答

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

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

char sep = '\n'  /1\
; int i = 68    /1  \
; while (i  ---      1\
                       \
                       /1/1/1                               /1\
                                                            /1\
                                                            /1\
                                                            /1\
                                                            /1\
                            /           1\
                           /            1 \
                          /             1  \
                         /              1   \
                         /1            /1    \
                          /1          /1      \
                           /1        /1        /1/1> 0) std::cout \
                              <<i<<                               sep;

对于较大数字, C++20 引入一些更先进的循环功能。 首先抓取i我们可以造一个反环环环环绕, 并把它偏移到std::ostream然而,i执行是定义的, 所以我们可以使用新的 C++20 速度操作器<<i<<我们必须通过建墙来赶上它,如果我们不这样做,i为指定分隔符,我们可以使用:

 std::cout \
           sep

在那里,我们有一个循环 从67到1。

此代码首先比较 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正在检查该条件。它不是-->,它,它是(x--) > 0

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

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