最新消息:欢迎加入小松的QQ群一起讨论一起学习,搜索的服务器网络有问题,导致搜索的功能没有办法用,现在已经修复了

php浮点数的精度问题深究

PHP 332浏览 0评论

前段时间同事在算个值的时候发现,算出来的值不对,于是来问我,之前的开发中也遇到过这个问题,已经记不清楚怎么处理的了,貌似用round四舍五入来着
今天就这个问题深入看一下
鸟哥的文章
PHP浮点数的一个常见问题的解答
已经解答了,这个问题产生的原因

那这么解决这个问题

我在php的官方找到了解决方法

原文地址http://php.net/manual/zh/language.types.float.php

php浮点数的精度

浮点数的精度
浮点数的精度有限。尽管取决于系统,PHP 通常使用 IEEE 754 双精度格式,则由于取整而导致的最大相对误差为 1.11e-16。非基本数学运算可能会给出更大误差,并且要考虑到进行复合运算时的误差传递。
此外,以十进制能够精确表示的有理数如 0.1 或 0.7,无论有多少尾数都不能被内部所使用的二进制精确表示,因此不能在不丢失一点点精度的情况下转换为二进制的格式。这就会造成混乱的结果:例如,floor((0.1+0.7)*10) 通常会返回 7 而不是预期中的 8,因为该结果内部的表示其实是类似 7.9999999999999991118…。
所以永远不要相信浮点数结果精确到了最后一位,也永远不要比较两个浮点数是否相等。如果确实需要更高的精度,应该使用任意精度数学函数或者 gmp 函数

上已经讲了解决方法是用任意精度数学函数或者 gmp 函数,具体用什么函数还是看官方文档

QQ交流群:136351212

如无特别说明,本站文章皆为原创,若要转载,务必请注明以下原文信息:
转载保留版权:小松博客» php浮点数的精度问题深究
本文链接地址:https://www.phpsong.com/2313.html

发表我的评论
取消评论
表情

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址
木有头像就木有JJ!点这里按步骤申请Gravatar头像吧!