運算符是一種告訴編譯器執行特定的數學或邏輯操做的符號。C 語言內置了豐富的運算符,並提供瞭如下類型的運算符:html
下表顯示了 C 語言支持的全部算術運算符。假設變量 A 的值爲 10,變量 B 的值爲 20,則:code
運算符 | 描述 | 實例 |
---|---|---|
+ | 把兩個操做數相加 | A + B 將獲得 30 |
- | 從第一個操做數中減去第二個操做數 | A - B 將獲得 -10 |
* | 把兩個操做數相乘 | A * B 將獲得 200 |
/ | 分子除以分母 | B / A 將獲得 2 |
% | 取模運算符,整除後的餘數 | B % A 將獲得 0 |
++ | 自增運算符,整數值增長 1 | A++ 將獲得 11 |
-- | 自減運算符,整數值減小 1 | A-- 將獲得 9 |
a++和++a是不一樣的htm
a++是先賦值後運算對象
++a是先運算後賦值get
下表顯示了 C 語言支持的全部關係運算符。假設變量 A 的值爲 10,變量 B 的值爲 20,則:編譯器
運算符 | 描述 | 實例 |
---|---|---|
== | 檢查兩個操做數的值是否相等,若是相等則條件爲真。 | (A == B) 爲假。 |
!= | 檢查兩個操做數的值是否相等,若是不相等則條件爲真。 | (A != B) 爲真。 |
> | 檢查左操做數的值是否大於右操做數的值,若是是則條件爲真。 | (A > B) 爲假。 |
< | 檢查左操做數的值是否小於右操做數的值,若是是則條件爲真。 | (A < B) 爲真。 |
>= | 檢查左操做數的值是否大於或等於右操做數的值,若是是則條件爲真。 | (A >= B) 爲假。 |
<= | 檢查左操做數的值是否小於或等於右操做數的值,若是是則條件爲真。 | (A <= B) 爲真。 |
下表顯示了 C 語言支持的全部關係邏輯運算符。假設變量 A 的值爲 1,變量 B 的值爲 0,則:數學
運算符 | 描述 | 實例 |
---|---|---|
&& | 稱爲邏輯與運算符。若是兩個操做數都非零,則條件爲真。 | (A && B) 爲假。 |
|| | 稱爲邏輯或運算符。若是兩個操做數中有任意一個非零,則條件爲真。 | (A || B) 爲真。 |
! | 稱爲邏輯非運算符。用來逆轉操做數的邏輯狀態。若是條件爲真則邏輯非運算符將使其爲假。 | !(A && B) 爲真。 |
位運算符做用於位,並逐位執行操做。io
假設若是 A = 60,且 B = 13,如今以二進制格式表示,它們以下所示:編譯
A = 0011 1100 B = 0000 1101 // 上下爲一組觀察 ----------------- A&B = 0000 1100 // 都1才1 A|B = 0011 1101 // 有1就1 A^B = 0011 0001 // 有1爲1,都1爲0 ~A = 1100 0011 // 0爲1,1爲0(反過來)
運算符 | 描述 | 實例 |
---|---|---|
<< | 二進制左移運算符。將一個運算對象的各二進制位所有左移若干位(左邊的二進制位丟棄,右邊補0)。 | A << 2 將獲得 240,即爲 1111 0000 |
>> | 二進制右移運算符。將一個數的各二進制位所有右移若干位,正數左補0,負數左補1,右邊丟棄。 | A >> 2 將獲得 15,即爲 0000 1111 |
請看下面的實例,瞭解 C 語言中全部可用的位運算符:table
#include <stdio.h> int main() { unsigned int a = 60; /* 60 = 0011 1100 */ unsigned int b = 13; /* 13 = 0000 1101 */ int c = 0; c = a & b; /* 12 = 0000 1100 */ printf("Line 1 - c 的值是 %d\n", c ); c = a | b; /* 61 = 0011 1101 */ printf("Line 2 - c 的值是 %d\n", c ); c = a ^ b; /* 49 = 0011 0001 */ printf("Line 3 - c 的值是 %d\n", c ); c = ~a; /*-61 = 1100 0011 */ printf("Line 4 - c 的值是 %d\n", c ); c = a << 2; /* 240 = 1111 0000 */ printf("Line 5 - c 的值是 %d\n", c ); c = a >> 2; /* 15 = 0000 1111 */ printf("Line 6 - c 的值是 %d\n", c ); }
當上面的代碼被編譯和執行時,它會產生下列結果:
Line 1 - c 的值是 12
Line 2 - c 的值是 61
Line 3 - c 的值是 49
Line 4 - c 的值是 -61
Line 5 - c 的值是 240
Line 6 - c 的值是 15
下表列出了 C 語言支持的賦值運算符:
運算符 | 描述 | 實例 |
---|---|---|
= | 簡單的賦值運算符,把右邊操做數的值賦給左邊操做數 | C = A + B 將把 A + B 的值賦給 C |
+= | 加且賦值運算符,把右邊操做數加上左邊操做數的結果賦值給左邊操做數 | C += A 至關於 C = C + A |
-= | 減且賦值運算符,把左邊操做數減去右邊操做數的結果賦值給左邊操做數 | C -= A 至關於 C = C - A |
*= | 乘且賦值運算符,把右邊操做數乘以左邊操做數的結果賦值給左邊操做數 | C = A 至關於 C = C A |
/= | 除且賦值運算符,把左邊操做數除以右邊操做數的結果賦值給左邊操做數 | C /= A 至關於 C = C / A |
%= | 求模且賦值運算符,求兩個操做數的模賦值給左邊操做數 | C %= A 至關於 C = C % A |
<<= | 左移且賦值運算符 | C <<= 2 等同於 C = C << 2 |
>>= | 右移且賦值運算符 | C >>= 2 等同於 C = C >> 2 |
&= | 按位與且賦值運算符 | C &= 2 等同於 C = C & 2 |
^= | 按位異或且賦值運算符 | C ^= 2 等同於 C = C ^ 2 |
|= | 按位或且賦值運算符 | C |= 2 等同於 C = C | 2 |
請看下面的實例,瞭解 C 語言中全部可用的賦值運算符:
#include <stdio.h> main() { int a = 21; int c ; c = a; printf("Line 1 - = 運算符實例,c 的值 = %d\n", c ); c += a; printf("Line 2 - += 運算符實例,c 的值 = %d\n", c ); c -= a; printf("Line 3 - -= 運算符實例,c 的值 = %d\n", c ); c *= a; printf("Line 4 - *= 運算符實例,c 的值 = %d\n", c ); c /= a; printf("Line 5 - /= 運算符實例,c 的值 = %d\n", c ); c = 200; c %= a; printf("Line 6 - %= 運算符實例,c 的值 = %d\n", c ); c <<= 2; printf("Line 7 - <<= 運算符實例,c 的值 = %d\n", c ); c >>= 2; printf("Line 8 - >>= 運算符實例,c 的值 = %d\n", c ); c &= 2; printf("Line 9 - &= 運算符實例,c 的值 = %d\n", c ); c ^= 2; printf("Line 10 - ^= 運算符實例,c 的值 = %d\n", c ); c |= 2; printf("Line 11 - |= 運算符實例,c 的值 = %d\n", c ); }
當上面的代碼被編譯和執行時,它會產生下列結果:
Line 1 - = 運算符實例,c 的值 = 21
Line 2 - += 運算符實例,c 的值 = 42
Line 3 - -= 運算符實例,c 的值 = 21
Line 4 - *= 運算符實例,c 的值 = 441
Line 5 - /= 運算符實例,c 的值 = 21
Line 6 - %= 運算符實例,c 的值 = 11
Line 7 - <<= 運算符實例,c 的值 = 44
Line 8 - >>= 運算符實例,c 的值 = 11
Line 9 - &= 運算符實例,c 的值 = 2
Line 10 - ^= 運算符實例,c 的值 = 0
Line 11 - |= 運算符實例,c 的值 = 2
下表列出了 C 語言支持的其餘一些重要的運算符,包括 sizeof 和 ? :。
運算符 | 描述 | 實例 |
---|---|---|
sizeof() | 返回變量的大小。 | sizeof(a) 將返回 4,其中 a 是整數。 |
& | 返回變量的地址。 | &a; 將給出變量的實際地址。 |
* | 指向一個變量。 | *a; 將指向一個變量。 |
? : | 條件表達式 | 若是條件爲真 ? 則值爲 X : 不然值爲 Y |
請看下面的實例,瞭解 C 語言中全部可用的雜項運算符:
#include <stdio.h> int main() { int a = 4; short b; double c; int* ptr; /* sizeof 運算符實例 */ printf("Line 1 - 變量 a 的大小 = %lu\n", sizeof(a) ); printf("Line 2 - 變量 b 的大小 = %lu\n", sizeof(b) ); printf("Line 3 - 變量 c 的大小 = %lu\n", sizeof(c) ); /* & 和 * 運算符實例 */ ptr = &a; /* 'ptr' 如今包含 'a' 的地址 */ printf("a 的值是 %d\n", a); printf("*ptr 是 %d\n", *ptr); /* 三元運算符實例 */ a = 10; b = (a == 1) ? 20: 30; printf( "b 的值是 %d\n", b ); b = (a == 10) ? 20: 30; printf( "b 的值是 %d\n", b ); }
當上面的代碼被編譯和執行時,它會產生下列結果:
Line 1 - 變量 a 的大小 = 4
Line 2 - 變量 b 的大小 = 2
Line 3 - 變量 c 的大小 = 8
a 的值是 4
*ptr 是 4
b 的值是 30
b 的值是 20
運算符的優先級會影響到一個表達式如何計算。某些運算符比其餘運算符有更高的優先級,例如,乘除運算符具備比加減運算符更高的優先級。
下表將按運算符優先級從高到低列出各個運算符,在表達式中,較高優先級的運算符會優先被計算。
類別 | 運算符 | 結合性 |
---|---|---|
後綴 | () [] -> . ++ - - | 從左到右 |
一元 | + - ! ~ ++ - - (type)* & sizeof | 從右到左 |
乘除 | * / % | 從左到右 |
加減 | + - | 從左到右 |
移位 | << >> | 從左到右 |
關係 | < <= > >= | 從左到右 |
相等 | == != | 從左到右 |
位與 AND | & | 從左到右 |
位異或 XOR | ^ | 從左到右 |
位或 OR | | | 從左到右 |
邏輯與 AND | && | 從左到右 |
邏輯或 OR | || | 從左到右 |
條件 | ?: | 從右到左 |
賦值 | = += -= *= /= %=>>= <<= &= ^= |= | 從右到左 |
逗號 | , | 從左到右 |