阅读后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) { // 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的启发。

其他回答

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

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。

这就是你的意思。

while((x--) > 0)

我们在童年的时候听到,

不要停,让走,让走,让走,让走,让走,让走,让走,让走,让走,让走,让走,让走,让走,让走,让走,让走,让走,让走,让走,让走,让走,让走,让走,让走,让走

当逗号混淆时

停止,不要松手。

现在在编程中也发生同样的情况, 空间制造混乱。 : D :

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

#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;
}

xC++的反方向可以更快地达到零:

int x = 10;

while( 0 <---- x )
{
   printf("%d ", x);
}

8 6 4 2

你可以用箭来控制速度!

int x = 100;

while( 0 <-------------------- x )
{
   printf("%d ", x);
}

90 80 70 60 50 40 30 20 10

;)