C語言中邏輯運算符與條件運算符的學習教程
邏輯運算符
邏輯運算符,用于對包含關(guān)系運算符的表達式進行組合,形成新的表達式;結(jié)果也是只有真或假兩種情況,結(jié)果值用 BOOL 類型變量存儲。
() [] -> . | 括號(函數(shù)等),數(shù)組,兩種結(jié)構(gòu)成員訪問 | |
! ~ ++ -- + -
* & (類型) sizeof |
否定,按位否定,增量,減量,正負號,
間接,取地址,類型轉(zhuǎn)換,求大小 |
|
* / % | 乘,除,取模 | |
+ - | 加,減 | |
<< >> | 左移,右移 | |
< <= >= > | 小于,小于等于,大于等于,大于 | |
== != | 等于,不等于 | |
& | 按位與 | |
^ | 按位異或 | |
| | 按位或 | |
&& | 邏輯與 | |
|| | 邏輯或 | |
? : | 條件 | |
= += -= *= /=
&= ^= |= <<= >>= |
各種賦值 | |
, | 逗號(順序) |
使用方法:
表達式1 邏輯運算符 表達式2
邏輯與:a >= b && a > 5 只有當運算符兩邊為真的時候這個表達式為真,一個表達式為假的時候,表達式的結(jié)果就為假。
int a = 5; int b = 6; if(a >= b && a > 5) { printf("表達式為真\n"); } else { printf("表達式為假\n"); } int a = 5; int b = 6; if(a >= b && a > 5) { printf("表達式為真\n"); } else { printf("表達式為假\n"); }
大家可以試著改變 a 和 b 的值看一下結(jié)果。
邏輯或:a >= b || a > 5 只要其中一個結(jié)果為真,這個表達式就為真。
int a = 6; int b = 7; if(a >= b || a > 5) { printf("表達式為真\n"); } else { printf("表達式為假\n"); } int a = 6; int b = 7; if(a >= b || a > 5) { printf("表達式為真\n"); } else { printf("表達式為假\n"); }
a >= b 為假,但是 a > 5 為真,所以會打?。罕磉_式為真。
邏輯非:!a,如果 a 為真,那么 !a 為假,如果 a 為假,那么 !a 為真。
BOOL flag = YES; printf("!flag = %d\n", !flag); printf("flag = %d\n", flag); BOOL flag = YES; printf("!flag = %d\n", !flag); printf("flag = %d\n", flag);
第一行打印輸出:!flag = 0
第二行打印輸出:flag = 1
邏輯運算符的短路
邏輯與的短路:&& 左側(cè)為假,右側(cè)不參與運算。
例如:
int a = 6; int b = 0; if(a >= 10 && b = 5) { printf("表達式的值為真\n"); } printf("b = %d\n", b); int a = 6; int b = 0; if(a >= 10 && b = 5) { printf("表達式的值為真\n"); } printf("b = %d\n", b);
這里 b 的輸出結(jié)果為:0,因為在表達式 a >= 10 && b = 5 中,a >= 6 為真,所以右側(cè)的 b = 5 不參與運算,所以 b 還等于原來的 0。
邏輯或的短路:|| 左側(cè)為真,右側(cè)不參與運算。
例如:
int a = 6; int b = 0; if(a >= 6 || b = 5) { printf("表達式的值為真\n"); } printf("b = %d\n", b); int a = 6; int b = 0; if(a >= 6 || b = 5) { printf("表達式的值為真\n"); } printf("b = %d\n", b);
這里 b 的輸出結(jié)果為:0,因為在表達式 a >= 6 || b = 5 中,a >= 6 為真,所以右側(cè)的 b = 5 不參與運算,所以 b 還等于原來的 0。
條件運算符
符號是這個 ?: 一個問號和一個冒號,英文字符。C 語言中唯一的一個三目運算符。
由條件運算符組成條件表達式的一般形式為:
條件表達式? 表達式1:表達式2
如果條件表達式為真,整個表達式的值為表達式1的值;
如果條件表達式為假,整個表達式的值為表達式2的值。
求三個數(shù)的最大值,使用條件運算符就是這樣寫:
int a = 5; int b = 6; int c = 9; int max = a > b ? a : b; max = max > c ? max : c; //也可以這樣寫,更加簡單 //int max = a > b ? (a > c ? a : c) : (b > c ? b : c); int a = 5; int b = 6; int c = 9; int max = a > b ? a : b; max = max > c ? max : c; //也可以這樣寫,更加簡單 //int max = a > b ? (a > c ? a : c) : (b > c ? b : c);
相關(guān)文章
VC++植物大戰(zhàn)僵尸中文版修改器實現(xiàn)代碼
這篇文章主要介紹了VC++植物大戰(zhàn)僵尸中文版修改器實現(xiàn)代碼,可實現(xiàn)植物大戰(zhàn)僵尸中的無限陽光與無冷卻時間功能,需要的朋友可以參考下2015-04-04簡要解讀C++的動態(tài)和靜態(tài)關(guān)聯(lián)以及虛析構(gòu)函數(shù)
這篇文章主要介紹了簡要解讀C++的動態(tài)和靜態(tài)關(guān)聯(lián)以及虛析構(gòu)函數(shù),析構(gòu)函數(shù)在C++編程中平時并不是太常用,需要的朋友可以參考下2015-09-09C++ Opencv imfill孔洞填充函數(shù)的實現(xiàn)思路與代碼
在Matlab下,使用imfill可以很容易的完成孔洞填充操作,下面這篇文章主要給大家介紹了關(guān)于C++ Opencv imfill孔洞填充函數(shù)的實現(xiàn)思路與代碼,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下2021-09-09如何利用C++實現(xiàn)mysql數(shù)據(jù)庫的連接池詳解
為了提高MySQL數(shù)據(jù)庫的訪問的瓶頸,除了在服務器端增設緩存服務器緩存常用的數(shù)據(jù)之外(如redis),還可以增加數(shù)據(jù)庫連接池,來提高MySQL Server的訪問效率,這篇文章主要給大家介紹了關(guān)于如何利用C++實現(xiàn)mysql數(shù)據(jù)庫的連接池的相關(guān)資料,需要的朋友可以參考下2021-07-07