C語言 詳細(xì)講解邏輯運(yùn)算符的使用
一、&& 與 II 分析
下面的程序運(yùn)行結(jié)束后,i, j,k 的值分別為多少?
#include <stdio.h> int main() { int i = 0; int j = 0; int k = 0; ++i || ++j && ++k; printf("i = %d\n", i); printf("j = %d\n", j); printf("k = %d\n", k); return 0; }
下面為輸出結(jié)果:
為什么 i = 1, j = 0, k = 0 呢?且看下面分析。
程序中的短路
|| 從左向右開始計(jì)算:
- 當(dāng)遇到為真的條件時(shí)停止計(jì)算,整個(gè)表達(dá)式為真
- 所有條件為假時(shí)表達(dá)式才為假
&& 從左向右開始計(jì)算:
- 當(dāng)遇到為假的條件時(shí)停止計(jì)算,整個(gè)表達(dá)式為假
- 所有條件為真時(shí)表達(dá)式才為真
邏輯表達(dá)式中,&& 比 || 具有更高的優(yōu)先級(jí)
在 && 和 || 混合運(yùn)算時(shí),整個(gè)表達(dá)式被看作 || 表達(dá)式,編譯器從左向右開始計(jì)算 && 表達(dá)式,當(dāng)某個(gè) && 表達(dá)式的值為真時(shí),停止計(jì)算,整個(gè)表達(dá)式的值為真。
這樣看來,上面代碼就可以解釋了。由于 i = 0;所以 ++i 就為 1,true && ++i 就為 1,根據(jù)短路法則,|| 從左向右開始計(jì)算,當(dāng)遇到為真的條件時(shí)停止計(jì)算,整個(gè)表達(dá)式為真。所以 ++j 和 ++k 都沒得到運(yùn)行,自然就是 0。
下面再看一個(gè)程序中的短路法則:
#include <stdio.h> int g = 0; int f() { printf("In f()...\n"); return g++; } int main() { if( g || f() && f() ) { printf("In if statement: %d\n", g); } printf("In main(): %d\n", g); return 0; }
弄懂了短路法則和 || 與 && 混合運(yùn)算法則,下面的輸出結(jié)果就很好理解了:
二、!分析
C語言中的邏輯非 “!” 只認(rèn)得 0,只知道見了 0 就返回 1。因此當(dāng)其碰見的值不是 0 時(shí),其結(jié)果為 0。(注意不只 1 才表示真,其他非 0 值都表示真)
下面看一段邏輯非運(yùn)算符使用的代碼:
#include <stdio.h> int main() { printf("%d\n", !0); printf("%d\n", !1); printf("%d\n", !100); printf("%d\n", !-1000); return 0; }
下面為輸出結(jié)果:
三、小結(jié)
程序中的邏輯表達(dá)式遵從短路規(guī)則
在 && 與 || 混合運(yùn)算時(shí):
- 整個(gè)表達(dá)式被看作 || 表達(dá)式
- 從左向右先計(jì)算 && 表達(dá)式
- 最后計(jì)算 || 表達(dá)式
邏輯非 ! 運(yùn)算符只認(rèn)得 0
碰見 0 返回 1,否則統(tǒng)統(tǒng)返回 0
注:只有 0 才代表假,其余的所有值均代表真。
到此這篇關(guān)于C語言 詳細(xì)講解邏輯運(yùn)算符的使用的文章就介紹到這了,更多相關(guān)C語言 邏輯運(yùn)算符內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
opencv+arduino實(shí)現(xiàn)物體點(diǎn)追蹤效果
這篇文章主要為大家詳細(xì)介紹了opencv+arduino實(shí)現(xiàn)物體點(diǎn)追蹤效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01C++設(shè)計(jì)模式之工廠方法模式的實(shí)現(xiàn)及優(yōu)缺點(diǎn)
工廠方法模式是一個(gè)創(chuàng)建型設(shè)計(jì)模式,通過定義一個(gè)創(chuàng)建對象的接口,讓其子類決定實(shí)例化哪一個(gè)工廠類,這篇文章主要給大家介紹了關(guān)于C++設(shè)計(jì)模式之工廠方法模式的實(shí)現(xiàn)及優(yōu)缺點(diǎn),需要的朋友可以參考下2021-06-06C++集體數(shù)據(jù)交換實(shí)現(xiàn)示例講解
這篇文章主要介紹了C++集體數(shù)據(jù)交換實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2022-11-11C++11特性小結(jié)之decltype、類內(nèi)初始化、列表初始化返回值
這篇文章主要介紹了C++11特性小結(jié)之decltype、類內(nèi)初始化、列表初始化返回值,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05C語言實(shí)現(xiàn)在數(shù)組A上有序合并數(shù)組B的方法
這篇文章主要介紹了C語言實(shí)現(xiàn)在數(shù)組A上有序合并數(shù)組B的方法,包含了數(shù)組操作的完整實(shí)現(xiàn)過程以及相應(yīng)的代碼分析與改進(jìn),具有不錯(cuò)的借鑒價(jià)值,需要的朋友可以參考下2014-09-09C++實(shí)現(xiàn)LeetCode(36.驗(yàn)證數(shù)獨(dú))
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(36.驗(yàn)證數(shù)獨(dú)),本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07