PHP浮点除零得INF/NAN不报错,整数除零抛DivisionByZeroError;防除零须显式判零而非isset();推荐filter_input过滤+判零,或空合并操作符??配合类型转换。

PHP怎么处理除数为零错误_PHP中isset和三元运算符说明【说明】

PHP除数为零不会报错,但结果是INF或Warning

PHP默认不中断执行,1 / 0 得到 INF0 / 0NAN,而整数除法(如 intdiv(5, 0))会直接抛出 DivisionByZeroError 异常。关键区别在于:浮点除法静默失效,整数除法强制报错。

常见错误现象:var_dump(10 / 0); 输出 float(INF),后续用它做比较(如 === 0)或传给 intval() 会得到意外结果;线上计算订单均价、分页总数时突然变成 INF,前端显示“INF”或触发JS NaN 错误。

isset() 不是用来判断“不为零”的

isset() 只检测变量是否已声明且不为 null,对 0false'' 都返回 true。很多人误用它来防除零,比如 if (isset($divisor)) { $result = $a / $divisor; } —— 这完全没用,$divisor = 0 时照样执行除法。

正确做法是单独判断值是否为零或空值:

三元运算符里嵌套 isset() 容易逻辑翻车

$val = isset($arr['key']) ? $arr['key'] : 0; 看似稳妥,但如果 $arr['key']0false'',这个三元表达式仍会走 else 分支,导致本该用的 0 被替换成默认值。

真正需要的是“键存在且非 null”,而不是“键存在且为真值”:

除零和空值检查混在一起时,顺序和类型最易出错

真实接口里经常要处理用户传来的 $_GET['limit']$_POST['page'],它们可能是字符串 "0"、空字符串、甚至根本没传。这时候一行判断很难兼顾所有边界。

最稳妥的组合是:先确保变量存在且是数字类型,再判零:

类型模糊、判断链过长、把 isset() 当万能开关——这三点加在一起,就是线上除零 bug 最常藏身的地方。

本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。