В таблице 2.1 показаны приоритеты и очередность вычислений всех операторов, включая и те, которые мы еще не рассматривали. Операторы, перечисленные на одной строке, имеют одинаковый приоритет: строки упорядочены по убыванию приоритетов; так, например, *, / и % имеют одинаковый приоритет, который выше, чем приоритет бинарных + и -. "Оператор” () относится к вызову функции. Операторы -> и . (точка) обеспечивают доступ к элементам структур; о них пойдет речь в главе 6, там же будет рассмотрен и оператор sizeof (размер объекта). Операторы * (косвенное обращение по указателю) и & (получение адреса объекта) обсуждаются в главе 5. Оператор "запятая” будет рассмотрен в главе 3.
Таблица 2.1. Приоритеты и очередность вычислений операторов
() | [] | -> | . | слева направо | |||||||
! | ~ | ++ | -- | + | - | * | & | (type) | sizeof | справа налево | |
* | / | % | слева направо | ||||||||
+ | - | слева направо | |||||||||
>> | слева направо | ||||||||||
> | >= | слева направо | |||||||||
== | != | слева направо | |||||||||
& | слева направо | ||||||||||
^ | слева направо | ||||||||||
| | слева направо | ||||||||||
&& | слева направо | ||||||||||
|| | слева направо | ||||||||||
?: | справа налево | ||||||||||
= | += | -= | *= | /= | %= | &= | ^= | |= | >>= | справа налево | |
, | слева направо |
Примечание. Унарные операторы +, -, * и & имеют более высокий приоритет, чем те же бинарные операторы.
Заметим, что приоритеты побитовых операторов &, ^ и | ниже, чем приоритет == и != , из-за чего в побитовых проверках, таких как
if ((x & MASK) == 0) ...
чтобы получить правильный результат, приходится использовать скобки. Си подобно многим языкам не фиксирует очередность вычисления операндов оператора (за исключением &&, ||, ?: и ,). Например, в инструкции вида
x = f() + g();
f может быть вычислена раньше g или наоборот. Из этого следует, что если одна из функций изменяет значение переменной, от которой зависит другая функция, то помещаемый в x результат может зависеть от очередности вычислений. Чтобы обеспечить нужную последовательность вычислений, промежуточные результаты можно запоминать во временных переменных.