=== 严格比较值和类型,避免隐式转换导致的误判;实操中应优先使用 === 判断用户输入、api 返回值等,用 strcmp/strcasecmp 比字符串,用 array_diff_assoc 或 json_encode 比数组/对象,避免手动类型转换后比较。

用 === 才算真正比较值和类型
PHP 的 == 会自动类型转换,=== 才严格比值又比类型。比如 0 == "0" 是 true,但 0 === "0" 是 false —— 这不是 bug,是设计如此。
实操建议:
立即学习“PHP免费学习笔记(深入)”;
- 判断用户输入、API 返回值、数据库字段时,一律优先用
=== -
null、false、空字符串""、整数0在==下容易互相“相等”,用===能立刻暴露类型不一致 - 函数返回
false表示失败(如strpos())、但可能合法返回0时,必须写strpos($str, 'a') === false,否则0 == false会误判
strcmp() 和 strcasecmp() 比字符串更可靠
直接用 === 比字符串看似简单,但遇到 null、数字、布尔值时会触发 PHP 的隐式转换规则,结果难预测。比如 "1" === 1 是 false,但 "1" === true 呢?其实是 false,可一旦混入数组或对象就直接报 Notice。
实操建议:
立即学习“PHP免费学习笔记(深入)”;
- 只比字符串内容是否完全一致(含大小写),用
strcmp($a, $b) === 0 - 忽略大小写比对,用
strcasecmp($a, $b) === 0 - 这两个函数对非字符串参数会静默转成字符串再比,比
===更稳定;且返回值是整数,能明确区分“小于/等于/大于”,不只是布尔真假
对象和数组不能靠 === 判断“内容相等”
=== 对对象比的是引用是否相同,对数组比的是结构和顺序是否完全一致(包括键名类型、顺序、嵌套深度)。它不递归深比较内容,也不做类型宽松处理。
实操建议:
立即学习“PHP免费学习笔记(深入)”;
- 要判断两个数组逻辑上“内容一样”,别用
===,改用array_diff_assoc($a, $b) === [] && array_diff_assoc($b, $a) === [],或封装成函数 - 对象之间想比属性值,
===几乎没用——除非你真在检查是不是同一个实例。该用json_encode($obj1) === json_encode($obj2)(注意:public 属性、无循环引用、无资源)或专门的比较库 - PHP 8.1+ 可用
match+ 类型检查组合判断,但不解决深比较问题
类型强制转换后用 === 反而更危险
有人觉得“我先转成 int 再比”,写成 (int)$a === (int)$b,以为更安全。其实这掩盖了原始类型信息,还可能引入截断或溢出问题。比如 (int)"99999999999999999999" 变成 PHP_INT_MAX,两个不同大数转完反而相等。
实操建议:
立即学习“PHP免费学习笔记(深入)”;
- 避免手动类型转换后再比,除非业务逻辑明确要求“只看数字部分”,且已约定输入格式
- 用
filter_var($val, FILTER_VALIDATE_INT)或is_int($val) && $val === $expected来验证并比较整数 - 对浮点数,永远别用
===直接比,改用abs($a - $b) 或 <code>bccomp($a, $b, 10) === 0
类型和值一起判断这件事,看起来只是多打两个等号,但背后是 PHP 类型系统的全部惯性。你得清楚自己是在比“它们是不是同一个东西”,还是“它们在当前上下文里能不能当同一个东西用”。前者用 ===,后者往往得自己定义规则。











