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