阅读后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);

    return 0;
}

产出将是:

9 8 7 6 5 4 3 2 1 0            

其他回答

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

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

这是两个操作员的组合 第一--用于减少值,并且>用于检查值是否大于右手操作。

#include<stdio.h>

int main()
{
    int x = 10;

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

    return 0;
}

产出将是:

9 8 7 6 5 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--;
    }
}

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

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

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

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

while( (x--) > 0 )

-->不是一个运算符, 它是一个并列--(后减少额)和>(比比较大)

循环将更熟悉于 :

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

此循环是一个经典的语法, 用于在10(被排除的上限)和0中包括低约束值,可用于对从最后到第一个阵列的数组的元素进行迭代。

初始值10是迭代的总数(例如数组的长度),加上循环中使用的第一个值。0最后一个值是x循环内循环,因此注释x 到 0 时为 0.

注意:x循环完成后-1.

请注意,该环环将运行相同方式,如果x具有 a 的无符号类型诸如size_t这是比天真的选择 更强的优势for (i = length-1; i >= 0; i--).

因此,我其实是这个令人惊讶的语法的粉丝:while (x --> 0)我发现这种有特色的眼神 和优雅的,就像for (;;)fs:while (1)(这看起来令人困惑地相似于while (l)它还使用其他语言,其语法受C++、客观-C、java、java、javascript、C#等C的启发。