C语言 详细讲解逻辑运算符的使用

 更新时间:2022年04月19日 15:46:09   作者:清风自在 流水潺潺  
在C语言中,逻辑运算符有&&、||、!;&&表示“与”的意思,需要两端的表达式的值都为true,该式的值才为true。||表示“或”的意思,两端的表达式的值只要有一端为true,该式的值就为true。!表示“非”的意思,将该式的真值换成相反的真值,即false和true互换

一、&& 与 II 分析

下面的程序运行结束后,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;
}

下面为输出结果:

为什么 i = 1, j = 0, k = 0 呢?且看下面分析。

程序中的短路

|| 从左向右开始计算:

  • 当遇到为真的条件时停止计算,整个表达式为真
  • 所有条件为假时表达式才为假

&& 从左向右开始计算:

  • 当遇到为假的条件时停止计算,整个表达式为假
  • 所有条件为真时表达式才为真

逻辑表达式中,&& 比 || 具有更高的优先级

在 && 和 || 混合运算时,整个表达式被看作 || 表达式,编译器从左向右开始计算 && 表达式,当某个 && 表达式的值为真时,停止计算,整个表达式的值为真。

这样看来,上面代码就可以解释了。由于 i = 0;所以 ++i 就为 1,true && ++i 就为 1,根据短路法则,|| 从左向右开始计算,当遇到为真的条件时停止计算,整个表达式为真。所以 ++j 和 ++k 都没得到运行,自然就是 0。

下面再看一个程序中的短路法则:

#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;
}

弄懂了短路法则和 || 与 && 混合运算法则,下面的输出结果就很好理解了:

二、!分析

C语言中的逻辑非 “!” 只认得 0,只知道见了 0 就返回 1。因此当其碰见的值不是 0 时,其结果为 0。(注意不只 1 才表示真,其他非 0 值都表示真)

下面看一段逻辑非运算符使用的代码:

#include <stdio.h>
int main()
{
    printf("%d\n", !0);
    printf("%d\n", !1);
    printf("%d\n", !100);
    printf("%d\n", !-1000);
    return 0;
}

下面为输出结果:

三、小结

程序中的逻辑表达式遵从短路规则

在 && 与 || 混合运算时:

  • 整个表达式被看作 || 表达式
  • 从左向右先计算 && 表达式
  • 最后计算 || 表达式

逻辑非 ! 运算符只认得 0

碰见 0 返回 1,否则统统返回 0

注:只有 0 才代表假,其余的所有值均代表真。

到此这篇关于C语言 详细讲解逻辑运算符的使用的文章就介绍到这了,更多相关C语言 逻辑运算符内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 如何写好C main函数的几个注意事项

    如何写好C main函数的几个注意事项

    这篇文章主要介绍了如何写好C main函数的几个注意事项,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-06-06
  • C++构造函数的类型,浅拷贝与深拷贝详解

    C++构造函数的类型,浅拷贝与深拷贝详解

    这篇文章主要为大家详细介绍了C++构造函数的类型,浅拷贝与深拷贝,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-03-03
  • C语言内存操作函数详解

    C语言内存操作函数详解

    这篇文章主要介绍了C语言全部内存操作函数的实现详细讲解,作者用图文代码实例讲解的很清晰,有感兴趣的同学可以研究下
    2021-10-10
  • C语言求逆矩阵案例详解

    C语言求逆矩阵案例详解

    这篇文章主要介绍了C语言求逆矩阵案例详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • C语言线索二叉树基础解读

    C语言线索二叉树基础解读

    线索二叉树还是按照链二叉树的方法创建,只不过在结点原本为空的左指针改为指向该结点在中序遍历中的前驱,结点原本为空的右指针改为指向该结点在中序遍历中的后继,也就是说把空的指针给利用了起来
    2022-04-04
  • C++ cin.getline及getline()用法详解

    C++ cin.getline及getline()用法详解

    这篇文章主要介绍了C++ cin.getline用法及C++ getline()的两种用法,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-02-02
  • C语言数据结构超详细讲解单向链表

    C语言数据结构超详细讲解单向链表

    链表可以说是一种最为基础的数据结构了,而单向链表更是基础中的基础。链表是由一组元素以特定的顺序组合或链接在一起的,不同元素之间在逻辑上相邻,但是在物理上并不一定相邻。在维护一组数据集合时,就可以使用链表,这一点和数组很相似
    2022-03-03
  • operator new在C++中的各种写法总结

    operator new在C++中的各种写法总结

    这篇文章并不是一个综合的手册,而是一个C++中各种内存分配方法的概述。它面向已经很熟悉C++语言的读者
    2013-09-09
  • C++深度优先搜索的实现方法

    C++深度优先搜索的实现方法

    这篇文章主要介绍了C++深度优先搜索的实现方法,是数据结构中非常重要的一种算法,需要的朋友可以参考下
    2014-08-08
  • 基于C++实现的哈夫曼编码解码操作示例

    基于C++实现的哈夫曼编码解码操作示例

    这篇文章主要介绍了基于C++实现的哈夫曼编码解码操作,结合实例形式分析了C++实现的哈夫曼编码解码相关定义与使用技巧,需要的朋友可以参考下
    2018-04-04

最新评论