我原来以为PHP中的and和&&是一样的, 只是写法上为了可读性和美观, 事实上我错了. 这里面深藏了一个坑!
看以下代码:
$bA = true;
$bB = false;
$b1 = $bA and $bB;
$b2 = $bA && $bB;
var_dump($b1); // $b1 = true
var_dump($b2); // $b2 = false
$bA = false;
$bB = true;
$b3 = $bA or $bB;
$b4 = $bA || $bB;
var_dump($b3); // $b3 = false
var_dump($b4); // $b4 = true
奇怪吧, and/&&和or/||出来的结果竟然不一样的. 问题出在哪里呢?
我们再看一段代码!
$bA = true;
$bB = false;
var_dump($bA and $bB); // false
var_dump($bA && $bB); // false
$bA = false;
$bB = true;
var_dump($bA or $bB); // true
var_dump($bA || $bB); // true
更奇怪, 这时怎么是对的. 所以问题可能出现在=上, 一番google和文档,终于找到了答案!
运算符优先级
通过这个表, 我们可以看到 and/&& 和 or/|| 这两组运算符的优先级竟然是不一样的. and和or的优先级是低于=的, 所以上面的代码就好理解了, 就是先做赋值然后再做了一个and或or的逻辑运算, 这个运算的结果并没有存下来. 所以最后出来让我们匪夷所思的结果.
结合性 |
运算符 |
额外信息 |
无结合性 |
clone new |
克隆和new |
左 |
[ |
数组 |
左 |
** |
算术 |
右 |
++ — ~ (int) (float) (string) (array) (object) (bool) @ |
类型和自增/自减 |
无结合性 |
instanceof |
类型 |
右 |
! |
逻辑运算 |
左 |
* / % |
算术 |
左 |
+ – . |
算术和字符串 |
左 |
<< >> |
按位运算 |
无结合性 |
< <= > >= |
比较运算 |
无结合性 |
== != === !== <> |
比较运算 |
左 |
& |
按位运算和引用 |
左 |
^ |
按位运算 |
左 |
| 按位运算 |
左 |
&& |
逻辑运算 |
左 |
| | 逻辑运算 |
左 |
?: |
三元条件选择 |
右 |
= += -= *= /= .= %= &= |
= ^= <<= >>= => | 赋值 |
左 |
and |
逻辑运算 |
左 |
xor |
逻辑运算 |
左 |
or |
逻辑运算 |
左 |
, |
很多使用 |