第三问:与、或、非与其截断原理

简介: 本文介绍了逻辑运算符“与”(&&)、“或”(||)和“非”(!)的基本功能及其真值表,并详细解释了它们的截断原理(短路求值)。文章还强调了在使用这些运算符时需要注意的类型转换、短路行为、优先级和可读性问题。

第三问:与、或、非与其截断原理

概述

逻辑运算符是编程中用于处理布尔值(真或假)的基本工具。在许多编程语言中,常用的逻辑运算符包括 &&(与)、||(或)和 !(非)。 &&(与)、||(或)运算符在使用时,要特别注意其截断的特性。

逻辑运算符

  1. 与运算符 (&&)
  • 功能:当且仅当两个操作数都为真时,结果为真。
  • 真值表
A B A 与 B
true true true
true false false
false true false
false false false
  1. 或运算符 (||)
  • 功能:只要有一个操作数为真,结果就为真。
  • 真值表
A B A 或 B
true true true
true false true
false true true
false false false
  1. 非运算符 (!)
  • 功能:对布尔值取反。如果操作数为真,结果为假;如果操作数为假,结果为真。
  • 真值表
A 非A
true false
false true

截断原理

截断原理(短路求值)是指在逻辑运算中,某些情况下可以提前停止计算,从而提高效率。

  • **与运算符 (&&)**:如果第一个操作数为假,整个表达式的结果必定为假,因此不会计算第二个操作数。

let a = false;
let b = (a && someFunction()); // someFunction() 不会被调用

  • **或运算符 (||)**:如果第一个操作数为真,整个表达式的结果必定为真,因此不会计算第二个操作数。

let a = true;
let b = (a || someFunction()); // someFunction() 不会被调用

注意事项

  1. 类型转换:在某些语言中,非布尔值会被转换为布尔值,可能导致意外结果。例如,在 JavaScript 中,0""nullundefinedNaN 被视为假。
  2. 短路行为:利用短路特性可以避免不必要的计算,但要小心副作用。例如,如果第二个操作数是一个函数调用,确保它在短路情况下不会被调用。
  3. 优先级:逻辑运算符的优先级可能会影响表达式的结果。通常,! 的优先级高于 &&,而 && 的优先级高于 ||。使用括号可以提高可读性并确保正确的计算顺序。
  4. 可读性:在复杂的逻辑表达式中,适当使用括号和分行可以提高代码的可读性,避免误解。
目录
相关文章
算法修炼Day52|● 300.最长递增子序列 ● 674. 最长连续递增序列 ● 718. 最长重复子数组
算法修炼Day52|● 300.最长递增子序列 ● 674. 最长连续递增序列 ● 718. 最长重复子数组
|
2月前
|
数据挖掘 索引 Python
如何在处理重复值时保持数据的原始顺序?
可以在处理数据重复值时有效地保持数据的原始顺序,确保数据在清洗和预处理过程中不会因为重复值的处理而导致顺序混乱,从而保证了数据分析结果的准确性和可靠性。
152 64
|
5月前
|
算法
【算法】滑动窗口——最小覆盖子串
【算法】滑动窗口——最小覆盖子串
|
8月前
leetcode代码记录(最长连续递增序列
leetcode代码记录(最长连续递增序列
50 2
|
算法 测试技术 C#
C++算法:拼接最大数
C++算法:拼接最大数
leetcode-76. 最小覆盖子串(滑动窗口)
时间复杂度:最坏情况下左右指针对 s 的每个元素各遍历一遍,哈希表中对 s 中的每个元素各插入、删除一次,对 t 中的元素各插入一次。每次检查是否可行会遍历整个 t 的哈希表,哈希表的大小与字符集的大小有关,设字符集大小为 CC,则渐进时间复杂度为 O(C⋅∣s∣+∣t∣)。
125 0
leetcode-76. 最小覆盖子串(滑动窗口)
LeetCode 1869. 哪种连续子字符串更长
给你一个二进制字符串 s 。如果字符串中由 1 组成的 最长 连续子字符串 严格长于 由 0 组成的 最长 连续子字符串,返回 true ;否则,返回 false 。
82 0
|
存储 数据库
长整数在插入较短的列时会被转换,但不会被截断为什么?公式是什么?
长整数在插入较短的列时会被转换,但不会被截断为什么?公式是什么?
|
人工智能 算法 JavaScript
最长连续不重复的序列
最长连续不重复的序列
|
算法 测试技术
【Day27】 LeetCode算法刷题(思路+注释)[801. 使序列递增的最小交换次数 ]
了解算法刷题(思路+注释)[801. 使序列递增的最小交换次数 ]。
133 0
【Day27】 LeetCode算法刷题(思路+注释)[801. 使序列递增的最小交换次数 ]