В предыдущей статье мы с вами рассмотрели бинарные операторы, которые используют для арифметических операций с двумя операндами (переменными). А в этом уроке мы научимся применять унарные операторы, для которых необходим один операнд. Называются они инкремент ( ++ ) и декремент (––). Роль этих операторов в том, чтобы изменить (увеличить или уменьшить соответственно) значение переменной на единицу, при этом значение будет перезаписано. Рассмотрим пример, в котором будем изменять значение переменной variable на единицу тремя различными способами:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 | #include <iostream> using namespace std; int main() { setlocale(LC_ALL, "rus"); int variable = 0; cout << variable << endl; variable = variable + 1; // обычный способ cout << variable << " - variable = variable + 1" << endl; variable += 1; // комбинированный оператор += cout << variable << " - variable += 1" << endl; variable++; // используем инкремент ++ cout << variable << " - variable++" << endl; variable--; // используем декремент -- variable--; variable--; cout << variable << " - три раза variable--" << endl; return 0; } |
После каждой операции в строках 11, 13 и 15. к значению переменной variable прибавляется единица. Как вы видите, самая короткая запись – это запись с использованием инкремента. Ниже, в строках 17 – 19, мы трижды применили декремент и в итоге получим значение variable уменьшенное на 3.
Компилируем:
Оба этих унарных оператора могут иметь две формы: постфиксную ( когда оператор расположен сразу за переменной) и префиксную (оператор расположен перед переменной). В рассмотренном примере мы применяли постфиксные формы инкремента и декремента. Чем же отличаются эти формы друг от друга? И первая и вторая формы этих операторов выполняют одинаковые роли – увеличение или уменьшение переменной на единицу. Но если в строке кода, где применяются инкремент или декремент, присутствуют еще какое-либо команды, тогда эти операторы по-разному себя ведут. Постфиксная форма будет применена после выполнения других команд. Посмотрим на следующем примере:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 | #include <iostream> using namespace std; int main() { setlocale(LC_ALL, "rus"); int variable = 0; // постфиксный инкремент // значение variable увеличится на 1 после показа на экран cout << variable++ << " - результат \"cout << variable++\" " << endl; cout << variable << " - изменённое значение" << endl; // префиксный инкремент // сразу увеличение на 1, потом показ на экран cout << ++variable << " - результат \"cout << ++variable\" " << endl; // та же логика для декремента // постфиксный декремент cout << variable-- << " - результат \"cout << variable--\" " << endl; cout << variable << " - изменённое значение" << endl; // префиксный декремент cout << --variable << " - результат \"cout << --variable\" " << endl; return 0; } |
В результате выполнения кода строки 12, мы увидим на экране число 0. Так произойдет потому, что увеличение на единицу выполнится после вывода значения переменной variable на экран. Чтобы убедиться, что значение действительно изменилось – в строке 13 просим показать нам variable. А вот в случае применения префиксной формы инкремента (строка 16), переменная сразу перезапишется и уже только после этого произойдет вывод на экран. Для декремента всё то же самое, но с уменьшением на единицу.
Компилируем:
Вот посмотрите еще на этот пример:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | #include <iostream> using namespace std; int main() { setlocale(LC_ALL, "rus"); int variable = 1; int a = 0; a = ++variable + 1 + ++variable * 2; cout << "a = " << a << endl; return 0; } |
Постарайтесь понять, почему в результате операций строки 11, переменная a стала равна 10. Задавать вопросы в комментариях не запрещается.
Как я понял: сначала компилятор вычисляет ++variable * 2 то есть (1+1)*2=4, затем он присваивает variable =4 и считает ++variable который вначале, то есть 4+1=5, в итоге получается: a=++variable + 1 + ++variable*2
a= 5 + 1 + 4
a= 10
Правильно???
Понял!!! всё гораздо проще a=3+1+3*2=4+6=10
А у меня выдает результат 7…
Как так?
Первыми выполняются операции инкремента, затем умножение, и, наконец, сложение.
Посмотри приоритет операций в С++.
у меня выходит 9
2 + 1 +(1+3×2)
Легко
3+1+((1+1+1)*2)
setlocale(LC_ALL, “rus”);
int variable = 1;
int a = 0;
a = ++variable + 1 + ++variable*2;
a=10
сначала выполняется: ++variable
int variable =2
дальше считает 2 ++variable
после он уже int variable =3
а теперь математика :3+1+3*2=10
a = ++variable + 1 + ++variable * 2;
1 a = ++variable + 1 + (++variable * 2);
++variable * 2 = ++variable будет 2, потом 2*2=4
2 a = (++variable + 1) + ++variable * 2;
( ++variable) + 1 = здесь ++variable уже равен 5 поскольку в первом
5 + 1 решении компилятор присвоил ему значение 4 то
дополнительный инкремент ( ++ ) увеличивает его еще
на 1, потом + цифра 1, следовательно 5+1=6
3 a = (++variable + 1) + (++variable * 2); и теперь складываем решение 1 и 2 с лева
6 + 4 на право это второе решение 6 плюс первое решение 4 равно 6+4=10
У вас ошибка. Ответ будет 9. Я точно не могу сказать почему, но терминал выводит ответ 9.
Undefined behaviour или вот ещё похожий случай:
int i=5,j=5;
i=++i+ ++i;
printf(“i=%i j=%i”, i, ++j + ++j); //Вывод: i=14 j=13