php中整数作布尔值时非零即真、零为假;位运算按补码处理;验证整数应用filter_var而非is_int或ctype_digit;数组键和switch中需防隐式转换陷阱。

PHP里整数怎么当布尔值用
PHP中整数直接用于if、while等判断时,只看是不是零:非零即真,零为假。这不是“转换”,而是语言内置的隐式判定规则。
-
0、-0(实际同0)→false -
1、-1、42、0x1A、0b101→ 全部是true - 注意:
0.0是浮点数,不是整数,但它也判为false;而0.1判为true,这点容易和整数混淆 - 类型不重要,值才重要——
(int)0、(string)"0"、null都在布尔上下文中为false,但它们语义不同,后续做严格比较(===)会出问题
位运算符对负整数怎么算
PHP的&、|、^、~、、<code>>>全按补码处理,32位或64位取决于平台(PHP_INT_SIZE)。负数不是简单加个符号位,得按补码逻辑来。
-
-1 & 1结果是1(因为-1补码全为1,最低位也是1) -
-1 >> 1是算术右移,高位补1,结果仍是-1;而0xFFFFFFFF >> 1(如果它是无符号大整数)行为可能不同——PHP没有无符号整型,所有整数带符号 - 用
左移负数易溢出:<code>-1 在32位系统上可能变成<code>0或触发未定义行为(实际常为0),别依赖 - 安全做法:先用
& 0xFF等掩码截取低8位再运算,避免高位干扰
用filter_var($x, FILTER_VALIDATE_INT)判断是否为有效整数
别用is_int()或ctype_digit()来验证用户输入的“整数字符串”,它们要么类型太死,要么不支持负号和进制前缀。
-
is_int("123")→false(字符串不是整型) -
ctype_digit("-123")→false(不认负号) -
filter_var("0xFF", FILTER_VALIDATE_INT, FILTER_FLAG_ALLOW_HEX)→255(成功解析) -
filter_var("12.3", FILTER_VALIDATE_INT)→false(小数点不行) - 注意:
filter_var(" 42 ", ...)默认会trim,但"42abc"会被截断成42——加FILTER_FLAG_STRIP_LOW没用,得配合正则或filter_var(..., FILTER_SANITIZE_NUMBER_INT)预处理
整型布尔判断在数组键和switch里的坑
数组键自动转整型,switch做松散比较,这两处最容易暴露隐式转换的副作用。
立即学习“PHP免费学习笔记(深入)”;
-
$arr = [0 => 'a', false => 'b'];→ 实际只有[0 => 'b'],因为false转为0覆盖了前者 -
switch (0) { case false: ... }会命中——case默认用==比较,不是=== - 想区分
0和false?必须用===显式判断,或改用match表达式(PHP 8.0+):match ($x) { 0 => ..., false => ... }支持严格匹配 - 从数据库读出的
tinyint(1)字段,MySQL扩展常返回字符串"0"或"1",直接丢进if没问题,但进switch就可能误匹配case 0:(因为"0" == 0)
tinyint字段直接扔进switch又没意识到它可能是字符串,这种地方一踩一个准。











