欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語(yǔ)言中邏輯運(yùn)算符與條件運(yùn)算符的學(xué)習(xí)教程

 更新時(shí)間:2016年04月26日 17:38:10   作者:靈犀  
這篇文章主要介紹了C語(yǔ)言中邏輯運(yùn)算符與條件運(yùn)算符的學(xué)習(xí)教程,條件運(yùn)算符問(wèn)號(hào)即三目運(yùn)算符使用起來(lái)十分方便,需要的朋友可以參考下

邏輯運(yùn)算符

邏輯運(yùn)算符,用于對(duì)包含關(guān)系運(yùn)算符的表達(dá)式進(jìn)行組合,形成新的表達(dá)式;結(jié)果也是只有真或假兩種情況,結(jié)果值用 BOOL 類型變量存儲(chǔ)。

運(yùn)算符
解釋
結(jié)合方式
() [] -> . 括號(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ì)算示例

    這篇文章主要介紹了使用單鏈表實(shí)現(xiàn)多項(xiàng)式計(jì)算示例,需要的朋友可以參考下
    2014-03-03
  • VC++植物大戰(zhàn)僵尸中文版修改器實(shí)現(xiàn)代碼

    VC++植物大戰(zhàn)僵尸中文版修改器實(shí)現(xiàn)代碼

    這篇文章主要介紹了VC++植物大戰(zhàn)僵尸中文版修改器實(shí)現(xiàn)代碼,可實(shí)現(xiàn)植物大戰(zhàn)僵尸中的無(wú)限陽(yáng)光與無(wú)冷卻時(shí)間功能,需要的朋友可以參考下
    2015-04-04
  • C語(yǔ)言從基礎(chǔ)到進(jìn)階全面講解數(shù)組

    C語(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ù)

    這篇文章主要介紹了簡(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ǔ)句的具體作用

    解析c語(yǔ)言switch中break語(yǔ)句的具體作用

    以下是對(duì)c語(yǔ)言switch中break語(yǔ)句的作用進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過(guò)來(lái)參考下
    2013-07-07
  • C++ Opencv imfill孔洞填充函數(shù)的實(shí)現(xiàn)思路與代碼

    C++ Opencv imfill孔洞填充函數(shù)的實(shí)現(xiàn)思路與代碼

    在Matlab下,使用imfill可以很容易的完成孔洞填充操作,下面這篇文章主要給大家介紹了關(guān)于C++ Opencv imfill孔洞填充函數(shù)的實(shí)現(xiàn)思路與代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2021-09-09
  • C語(yǔ)言中單鏈表的基本操作指南(增刪改查)

    C語(yǔ)言中單鏈表的基本操作指南(增刪改查)

    鏈表跟數(shù)組不同的是非連續(xù)存儲(chǔ)結(jié)構(gòu),也就是說(shuō)實(shí)現(xiàn)鏈表需要一個(gè)指針,每用完一個(gè)節(jié)點(diǎn)指針指向下一個(gè)節(jié)點(diǎn),直至表尾,下面這篇文章主要給大家介紹了關(guān)于C語(yǔ)言中單鏈表的基本操作之增刪改查的相關(guān)資料,需要的朋友可以參考下
    2021-09-09
  • c++制作的時(shí)間函數(shù)類

    c++制作的時(shí)間函數(shù)類

    本文給大家分享的是一個(gè)個(gè)人使用C++編寫的時(shí)間函數(shù)類,主要是實(shí)現(xiàn)了類的定義和調(diào)用,相比較來(lái)說(shuō)還算比較復(fù)雜的時(shí)間類了,推薦給小伙伴們,有需要的朋友可以參考下。
    2015-03-03
  • 如何利用C++實(shí)現(xiàn)mysql數(shù)據(jù)庫(kù)的連接池詳解

    如何利用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
  • C語(yǔ)言基礎(chǔ)全局變量與局部變量教程詳解

    C語(yǔ)言基礎(chǔ)全局變量與局部變量教程詳解

    此處對(duì)于全局與局部做一些簡(jiǎn)要的介紹,包括全局變量與局部變量,靜態(tài)全局變量與靜態(tài)局部變量,全局函數(shù)與靜態(tài)函數(shù),作者實(shí)屬初學(xué),文中若有理解不當(dāng)之處,還請(qǐng)朋友們不吝指正
    2021-11-11

最新評(píng)論