c++ таблица - Что такое оператор «->» в C ++?




11 Answers

Обращать внимание

--> не является оператором. Это фактически два отдельных оператора, -- и > .

Условный код уменьшает x , возвращая исходное (не уменьшенное) значение x , а затем сравнивает исходное значение с 0 с помощью оператора > .

Чтобы лучше понять, заявление можно было бы написать следующим образом:

while((x--) > 0)
операторы перегрузка

Прочитав Hidden Features и Dark Corners из C ++ / STL на comp.lang.c++.moderated , я был полностью удивлен тем, что следующий фрагмент скомпилирован и работал как в Visual Studio 2008, так и в G ++ 4.4.

Вот код:

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

Я бы предположил, что это C, так как он работает и в GCC. Где это определено в стандарте и откуда оно взялось?




Это очень сложный оператор, поэтому даже ISO / IEC JTC1 (Joint Technical Committee 1) разместил свое описание в двух разных частях стандарта C ++.

Шутки в сторону, они представляют собой два разных оператора: -- и > описанные соответственно в п. 5.2.6 / 2 и §5.9 стандарта C ++ 03.




x может идти до нуля еще быстрее в противоположном направлении:

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

;)




Использование --> имеет историческую значимость. Decrementing был (и по-прежнему в некоторых случаях), быстрее, чем приращение архитектуры x86. Использование --> предполагает, что 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;
}



Это точно так же, как

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

для неотрицательных чисел




Этот код сначала сравнивает x и 0, а затем уменьшает x. (Также сказано в первом ответе: вы пост-декрементируете 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



Между -- и > отсутствует пробел. x пост декрементируется, то есть уменьшается после проверки условия x>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            



C и C++ подчиняются правилу «максимум munch». Точно так же, как --- b переводится на (a--) - b , в вашем случае x-->0 переводит (x--)>0 .

То, что правило говорит в основном, состоит в том, что движение слева направо, выражения формируются путем принятия максимума символов, которые будут формировать правильное выражение.




Обычным способом мы определяем условие в круглой скобке цикла « () » и условие завершения внутри фигурных скобок « {} », но это -- & > - это способ, которым каждый определяет все сразу. Например:

int abc(){
    int a = 5
    while((a--) > 0){ // Decrement and comparison both at once
        // Code
    }
}

Он говорит, уменьшает a и запускает цикл до тех пор, пока время a больше 0

Другим способом это должно было быть:

int abc(){
    int a = 5
    while(a > 0){
        // Code
        a = a -1 // Decrement inside loop
    }
}

в обоих направлениях мы делаем то же самое и достигаем тех же целей.




Related