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


当前回答

C++ 和 C++ 遵守“ 最大食量” 规则。 与 a- b 被翻译为 (a-) - b 的方式相同, 在您的情况下 x - > 0 被翻译为 (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

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

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

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

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

在此代码版本中, 循环时使用 > 运算符测试 x 是否大于 0 。 x- 语句用于在循环每次迭代结束时将 x 降为 1 。

这个 -- > 根本不是一个操作员。 我们有一个类似 -- > 的操作员, 但不像 -- > 。 这只是对时间( x - - - > 0) 的错误解释, 仅仅表示 x 有后衰落操作员, 而这个循环会运行到它大于零 。

写这个代码的另一种简单方式是时间( x - - ) 。 当它出现虚假状况时, 循环就会停止, 这里只有一个案例, 即 0 。 所以当 x 值降为零时它就会停止 。

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

 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) 评估为假值, 而循环退出时则评估为假值 。

丑陋的怪胎, 但我会使用这个:

#define as ;while

int main(int argc, char* argv[])
{
    int n = atoi(argv[1]);
    do printf("n is %d\n", n) as ( n --> 0);
    return 0;
}