C++運算子優先順序

辜铜星發表於2024-08-21
優先順序運算子描述例子結合性
1()
[]
->
.
::
++
--
調節優先順序的括號運算子
陣列下標訪問運算子
透過指向物件的指標訪問成員的運算子
透過物件本身訪問成員的運算子
作用域運算子
後置自增運算子
後置自減運算子
(a + b) / 4;
array[4] = 2;
ptr->age = 34;
obj.age = 34;
Class::age = 2;
for( i = 0; i < 10; i++ ) ...
for( i = 10; i > 0; i-- ) ...
從左到右
2!
~
++
--
-
+
*
&
(type)
sizeof
邏輯取反運算子
按位取反(按位取補)
前置自增運算子
前置自減運算子
一元取負運算子
一元取正運算子
解引用運算子
取地址運算子
型別轉換運算子
返回物件佔用的位元組數運算子
if( !done ) ...
flags = ~flags;
for( i = 0; i < 10; ++i ) ...
for( i = 10; i > 0; --i ) ...
int i = -1;
int i = +1;
data = *ptr;
address = &obj;
int i = (int) floatNum;
int size = sizeof(floatNum);
從右到左
3->*
.*
在指標上透過指向成員的指標訪問成員的運算子
在物件上透過指向成員的指標訪問成員的運算子
ptr->*var = 24;
obj.*var = 24;
從左到右
4*
/
%
乘法運算子
除法運算子
取餘數運算子
int i = 2 * 4;
float f = 10 / 3;
int rem = 4 % 3;
從左到右
5+
-
加法運算子
減法運算子
int i = 2 + 3;
int i = 5 - 1;
從左到右
6<<
>>
按位左移運算子
按位右移運算子
int flags = 33 << 1;
int flags = 33 >> 1;
從左到右
7<
<=
>
>=
小於比較運算子
小於或等於比較運算子
大於比較運算子
大於或等於比較運算子
if( i < 42 ) ...
if( i <= 42 ) ...
if( i > 42 ) ...
if( i >= 42 ) ...
從左到右
8==
!=
等於比較運算子
不等於比較運算子
if( i == 42 ) ...
if( i != 42 ) ...
從左到右
9&按位與運算子flags = flags & 42;從左到右
10^按位異或運算子flags = flags ^ 42;從左到右
11|按位或運算子flags = flags | 42;從左到右
12&&邏輯與運算子if( conditionA && conditionB ) ...從左到右
13||邏輯或運算子if( conditionA || conditionB ) ...從左到右
14? :三元條件運算子int i = (a > b) ? a : b;從右到左
15=
+=
-=
*=
/=
%=
&=
^=
|=
<<=
>>=
賦值運算子
複合賦值運算子(加法)
複合賦值運算子(減法)
複合賦值運算子(乘法)
複合賦值運算子(除法)
複合賦值運算子(取餘)
複合賦值運算子(按位與)
複合賦值運算子(按位異或)
複合賦值運算子(按位或)
複合賦值運算子(按位左移)
複合賦值運算子(按位右移)
int a = b;
a += 3;
b -= 4;
a *= 5;
a /= 2;
a %= 3;
flags &= new_flags;
flags ^= new_flags;
flags |= new_flags;
flags <<= 2;
flags >>= 2;
從右到左
16,逗號運算子for( i = 0, j = 0; i < 10; i++, j++ ) ...從左到右

相關文章