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

C語言 詳細(xì)講解邏輯運(yùn)算符的使用

 更新時(shí)間:2022年04月19日 15:46:09   作者:清風(fēng)自在 流水潺潺  
在C語言中,邏輯運(yùn)算符有&&、||、!;&&表示“與”的意思,需要兩端的表達(dá)式的值都為true,該式的值才為true。||表示“或”的意思,兩端的表達(dá)式的值只要有一端為true,該式的值就為true。!表示“非”的意思,將該式的真值換成相反的真值,即false和true互換

一、&& 與 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)文章

  • 純C語言:遞歸組合數(shù)源碼分享

    純C語言:遞歸組合數(shù)源碼分享

    這篇文章主要介紹了純C語言:遞歸組合數(shù)源碼,有需要的朋友可以參考一下
    2014-01-01
  • opencv+arduino實(shí)現(xiàn)物體點(diǎn)追蹤效果

    opencv+arduino實(shí)現(xiàn)物體點(diǎn)追蹤效果

    這篇文章主要為大家詳細(xì)介紹了opencv+arduino實(shí)現(xiàn)物體點(diǎn)追蹤效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • C++設(shè)計(jì)模式之工廠方法模式的實(shí)現(xiàn)及優(yōu)缺點(diǎn)

    C++設(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-06
  • C語言位圖及位圖的實(shí)現(xiàn)

    C語言位圖及位圖的實(shí)現(xiàn)

    這篇文章主要為大家詳細(xì)介紹了C語言位圖及位圖的實(shí)現(xiàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • C++集體數(shù)據(jù)交換實(shí)現(xiàn)示例講解

    C++集體數(shù)據(jù)交換實(shí)現(xiàn)示例講解

    這篇文章主要介紹了C++集體數(shù)據(jù)交換實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-11-11
  • C語言常見排序算法之交換排序(冒泡排序,快速排序)

    C語言常見排序算法之交換排序(冒泡排序,快速排序)

    這篇文章主要介紹了C語言常見排序算法之交換排序(冒泡排序,快速排序),冒泡排序即Bubble?Sort,類似于水中冒泡,較大的數(shù)沉下去,較小的數(shù)慢慢冒起來,假設(shè)從小到大,即為較大的數(shù)慢慢往后排,較小的數(shù)慢慢往前排
    2022-07-07
  • Qt使用QWT繪制柱狀圖詳解

    Qt使用QWT繪制柱狀圖詳解

    QT中提供了一個(gè)叫做QWT的庫。QWT,全稱是Qt?Widgets?for?Technical?Applications,是一個(gè)基于LGPL版權(quán)協(xié)議的開源項(xiàng)目,可生成各種統(tǒng)計(jì)圖。本文將通過它繪制柱狀圖,需要的可以參考一下
    2022-01-01
  • C++11特性小結(jié)之decltype、類內(nèi)初始化、列表初始化返回值

    C++11特性小結(jié)之decltype、類內(nèi)初始化、列表初始化返回值

    這篇文章主要介紹了C++11特性小結(jié)之decltype、類內(nèi)初始化、列表初始化返回值,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-05-05
  • C語言實(shí)現(xiàn)在數(shù)組A上有序合并數(shù)組B的方法

    C語言實(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-09
  • C++實(shí)現(xiàn)LeetCode(36.驗(yàn)證數(shù)獨(dú))

    C++實(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

最新評(píng)論