我经常在我的代码中使用($ var& 1),如果 $ var 是奇数,则返回true,如果是偶数,则返回false。 / p>

但“&”是什么呢?实际上呢?

有帮助吗?

解决方案

&安培;是二进制。如果您有二进制值,并且具有另一个二进制值,那么结果将是两者的按位。一个例子:

  01101010
& 01011001
= 01001000

最右边的位是1(在这种情况下,数字是奇数)或者是0,在这种情况下,数字是偶数。如果& 一个带1的数字,则只查看最低有效位,if检查数字是1还是0.正如其他人所提到的那样,查看按位运算符关于它们如何工作的信息。

其他提示

两个对二进制系统至关重要的操作是OR和AND。

OR表示'如果A打开或B打开'。一个真实的例子是并行的两个开关。如果其中一个允许电流通过,则电流通过。

AND表示'如果A和B都打开'。现实世界的例子是两个串联的开关。只有当两者都允许电流通过时,电流才会通过。

在计算机中,这些不是物理开关,而是半导体,其功能称为逻辑门。它们与开关做同样的事情 - 对电流或无电流做出反应。

当应用于整数时,一个数字中的每个位与另一个数字中的每个位组合。因此,要理解按位运算符OR和AND,需要将数字转换为二进制,然后对每对匹配位执行OR或AND运算。

这就是为什么:

00011011 (odd number)
AND
00000001 (& 1)
== 
00000001 (results in 1)

尽管

00011010 (even number)
AND
00000001 (& 1)
==
00000000 (results in 0)

因此,(& 1)操作使用AND逻辑将最右边的位与1进行比较。所有其他位都被有效忽略,因为任何东西都没有任何东西。二进制中的偶数也是十进制表示法中的偶数(10是2的倍数)。

二进制系统的其他基本操作包括NOT和XOR。 NOT表示“如果A关闭”,并且是唯一一种只接受一个信号或“参数”而不是两个信号的逻辑门形式。 XOR表示'如果A或B打开,但不是两者'。然后是NAND,NOR和NXOR,它们基本上没有与AND,OR和XOR结合,即NAND意味着'如果A和B 两者都在'。

在编程中,操作员

& means AND,
| means OR, 
~ means NOT, and
^ means XOR.

其他可以通过组合这些来组成,例如:

~ (a & b) is equivalent to a NAND operation

PHP特定说明

按位运算符不适用于浮点值,而PHP浮点值将首先隐式转换为整数。可以表示为整数的范围之外的数字将被截断为零 - 也就是说,PHP_INT_MAX上的所有数字都将看起来“偶数”。在表达式($ num& 1)中。如果要支持PHP_INT_MIN / PHP_INT_MAX之外的数字,则需要 fmod($ num,2)但是,如果您使用的是64位PHP,那么整数将比浮点数具有更高的精度。

了解bitwise和PHP也很有趣:

/**
 * Regular
 */
echo (true && true); // 1
echo (true && false); // nothing

echo (true || false); // 1
echo (false || false); // nothing

echo (true xor false); // 1
echo (false xor false); // nothing

/**
 * Bitwise
 */
echo (true & true); // 1
echo (true & false); // 0

echo (true | false); // 1
echo (false | false); // 0

echo (true ^ false); // 1
echo (false ^ false); // 0

除了其他答案之外,值得注意的是

if(func1() && func2())

如果 func1()返回true(“懒惰评估”),则只会调用 func2(),而

if(func1() & func2())

无论如何都会调用这两个函数,但两者的真值表都是相同的(假设它们返回布尔值)。


thomasrutter指出(在下面的评论中)你可能不应该在实践中做后者。 (A&amp; B)不一定与(A&amp;&amp; B)具有相同的真实性,特别是当 A 和<代码> B 是整数。例如,如果A = 1且B = 2(两者都是真实的),A&amp; B将是假的,而A&amp;&amp; amp; B是真实的。此外,另一位开发人员可能认为这是一个拼写错误,并将其“更正”为两个&符号。

我知道你的问题是关于理解按位运算符,并且接受的答案解释得很好。但是对于你给出的例子,我不禁建议你使用模运算符:

($var % 2) /* instead of */ ($var & 1)

因为它清楚地表明您正在检查数字是否为奇数(不能被2整除),并且它更通用,所以您可以使用相同的方式使用($ var%3)并推断它的工作原理任何N.

scroll top