php严格比较必须用===和!==,因松散比较会自动类型转换导致逻辑错误,如"0"==false为true而"0"===false为false;函数返回值、用户输入、枚举校验、in_array等场景不强制严格比较必出bug。

PHP严格比较用===还是!==?
严格比较必须用 === 和 !==,不是 == 或 !=。PHP在松散比较时会自动类型转换,比如 "0" == false 居然为 true,而 "0" === false 是 false——这是绝大多数逻辑错乱的源头。
常见错误现象:
- 表单提交的
"0"被当成false导致权限跳过 - API返回的字符串
"1"和整数1用==判等成功,但后续运算出错 -
in_array("0", $arr)返回true,哪怕数组里只有整数0(默认开启松散匹配)
哪些场景必须强制严格比较?
不是“建议”,是“不这么做就会出bug”的硬性场景:
- 判断函数返回值是否为
false(如fopen()、strpos()),因为0和false都是“falsy”,但语义完全不同 - 处理用户输入(
$_GET、$_POST)和数据库读取的字段,它们几乎全是字符串 - 枚举值校验,比如状态码
$status === 200,不能容忍"200"或200.0 - 使用
in_array()、array_search()时,第三个参数必须传true,否则默认松散匹配
strict_types=1 能替代 === 吗?
不能。声明 declare(strict_types=1); 只影响**函数参数和返回值的类型声明检查**,对变量间比较、if 条件、switch 分支完全无效。
立即学习“PHP免费学习笔记(深入)”;
例如:
declare(strict_types=1);
function foo(int $x): int { return $x; }
foo("1"); // TypeError:这里被拦截
if ("1" == 1) { } // ✅ 依然执行,strict_types 不管这个
所以别指望它帮你兜底比较逻辑。
容易忽略的兼容性细节
严格比较本身没兼容性问题,但要注意这些隐性陷阱:
-
null === NULL成立,但NULL是常量,null是关键字,两者在严格比较中等价;不过写成null更规范 -
0.0 === 0是false(float vs int),但0.0 == 0是true;浮点数慎用严格比较,除非你明确知道类型 - 对象比较用
===是判断是否为同一实例(identity),不是属性值相等;要值相等得自己写方法 - 数组空值判断别只写
$arr === [],PHP 7.4+ 支持,但老版本会报错;稳妥写法是is_array($arr) && empty($arr)
类型混杂的地方,光看值不够,得盯住类型本身——这才是严格比较真正要你花力气确认的部分。











