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


当前回答

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 引入一些更先进的环绕功能。 首先, 抓住我, 我们可以建立一个反环绕行, 并将其偏移到 std:: ostream 上。 但是, i 的速度是执行定义的, 这样我们可以使用新的 C++20 速度操作器 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

这里 -- -- 是一个纯净的后衰减操作员。

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

开始时, 条件会以 (x > 0) / / / 10 > 0 来评价 (x > 0) / / 10 > 0 。 现在, 因为条件是真实的, 它会以衰减值 x - / x = 9 = 9 进入循环。 这就是为什么第一个打印值是 9 等。 在最后一个循环 x= 1 中, 条件是真实的 。 根据非自动运算符, 在打印时, 值将修改为 x = 0 。 现在, x = 0, 它会将条件 (x > 0) 评估为假值, 而循环退出时则评估为假值 。

- >不是一个操作员。它实际上是两个单独的操作员,--和 >。

条件值的代码缩进 x, 同时返回 x 的原始值( 未降值 ) , 然后使用 > 运算符将原始值与 0 比较 。

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

while( (x--) > 0 )

( -- > 0) 系指 (x - - > 0) 。

您可以使用 (x -- >) 输出: 9 8 7 7 6 5 4 4 3 2 1 0

输出: 9 8 7 7 6 5 5 4 3 2 1

您可以使用

(--\
    \
     x > 0)

产出: 9 8 8 7 7 6 5 4 4 3 2 1

您可以使用

(\
  \
   x --> 0)

产出: 9 8 8 7 7 6 5 4 4 3 2 1 0

您可以使用

(\
  \
   x --> 0
          \
           \
            )

产出: 9 8 8 7 7 6 5 4 4 3 2 1 0

您也可以使用

(
 x 
  --> 
      0
       )

产出: 9 8 8 7 7 6 5 4 4 3 2 1 0

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

相对于常规箭头操作员 (- >) , 您可以使用穿甲箭头操作员 : -- x> (注意箭头上那些尖锐的条纹) 。 它会为穿甲添加+1 。 因此它比常规箭头操作员更快完成环形 1 迭代 。 请尝试 :

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