php 浮点数计算问题,PHP 浮点型运算相关问题

php 浮点数计算比较及取整不准确。举例:

$a = 0.2+0.7;

$b = 0.9;

var_dump($a == $b); //输出的结果为bool(false)

PHP 官方手册说明:显然简单的十进制分数如 0.2 不能在不丢失一点点精度的情况下转换为内部二 进制的格式。

printf(“%0.20f”, $a); //输出的结果为0.89999999999999991118

printf(“%0.20f”, $b); //输出的结果为0.90000000000000002220

根据结果说明,作为浮点型数据,其精度已经损失了一部分,达不到完全精确。所以永远不要相信浮点数结果精确到了最后一位,也永远不要比较两个浮点数是否相等。

需要说明的是,这不是 PHP 的 问题,而是计算机内部处理浮点数的问题!在 C、JAVA 等语言中也会遇到同样的问题。

解决方法:需要将其控制在我们需要的精度范围内再行比较。

因此使用 bcadd() 函数 来对浮点数想加并进行精度转换(为字符串):

var_dump(bcadd(0.2,0.7,1) == 0.9); // 输出的结果为bool(true)

也可以使用round() 函数是按照指定的精度进行四舍五入:

var_dump(round(0.2+0.7,2) == 0.9);// 输出的结果为bool(true)

关于浮点数精度的注意事项:

简单的十进制分数如同 0.1 或 0.7 在转换为内部二进制的格式会丢失精度:

例如,floor((0.1+0.7)*10) 通常会返回 7 而不是预期中的 8,因为该结果内部的表示其实是7.9。

就是不可能精确的用有限位数表达某些十进制分数。

例如,十进制的 1/3 变成了 0.3。

所以

1。永远不要相信浮点数结果精确到了最后一位,

2。也永远不要比较两个浮点数是否相等。

3。如果确实需要更高的精度,应该使用任意精度数学函数或者 gmp 函数。

自 PHP 5 起,如果试图将对象转换为浮点数,会发出一条 E_NOTICE 错误。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值