php判断奇偶数最安全用$n % 2 !== 0,因%是取余对负数如-3%2得-1;大数用bcmod('n','2')=== '0';位运算&1仅适用非负整数;避免类型混淆导致误判。

用 % 判断奇偶数最直接,但要注意负数
PHP 中判断奇偶数,核心就是看除以 2 的余数是否为 0。用 % 运算符即可,$n % 2 === 0 表示偶数,$n % 2 === 1 表示奇数。
但注意:PHP 的 % 是「取余」(remainder),不是「取模」(modulo)。对负数行为和很多语言不一致——比如 -3 % 2 结果是 -1,不是 1。所以直接用 === 1 判奇数会漏掉负奇数。
- 安全写法是:
$n % 2 !== 0(非零即奇)或abs($n) % 2 === 1 - 如果业务确定输入全是非负整数(如循环索引、ID),
$n % 2 === 1完全没问题 - 避免用
==,因为1 == true成立,而$n % 2可能返回true(隐式转换后),造成误判
用 bcmod() 处理大整数时的奇偶判断
当数字超出 int 范围(比如字符串形式的大数),% 会先强制转为 float 或 int,精度丢失,结果不可靠。这时得用任意精度函数。
bcmod() 是唯一能安全处理超长数字字符串的内置方案,但它只接受字符串参数,且第二个参数必须是正整数字符串。
立即学习“PHP免费学习笔记(深入)”;
- 正确调用:
bcmod('12345678901234567890', '2') === '0' - 错误写法:
bcmod(12345678901234567890, 2)—— 数字字面量已溢出 -
bcmod()返回的是字符串,必须用=== '0'或=== '1'比较,不能用== 0
性能差异:%、&、fmod() 怎么选
多数场景用 % 就够了,但有人会想用位运算 & 1 加速——它确实快,但有前提限制。
-
$n & 1仅适用于非负整数,且在 PHP 中对负数行为依赖底层补码表示,不跨平台可移植 -
fmod()是浮点取余函数,返回 float,用于小数场景(如3.7 % 2不合法,但fmod(3.7, 2)可行),但判断奇偶没意义——奇偶性只针对整数定义 - 实测:对百万次整数判断,
%和& 1性能差距微乎其微(纳秒级),别为这点优化牺牲可读性和健壮性
常见报错和类型陷阱
最常踩的坑不是逻辑错,而是类型混入导致意外结果。
-
'5' % 2没问题(PHP 自动转 int),但'5.5' % 2会转成5 % 2→1,静默截断,容易埋雷 - 从
$_GET或数据库取来的值,可能是 string 或 null,null % 2返回0(PHP 把 null 当 0),但业务上 null 不该被当作偶数 - 错误现象:
var_dump(0 == false)→true,所以if (!$n % 2)这种写法在$n = 0时成立,但$n = ''或$n = null也成立,完全失控
真要保险,先断言类型:is_int($n) && $n % 2 === 0,或者用 strict 类型检查 + 强制转换。











