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

