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 等语言中也会遇到同样的问题。

 

解决方法:

1)需要将其控制在我们需要的精度范围内再行比较。
因此使用 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)

 
2)BCMath扩展
bcadd: 将二个高精确度数字相加。
bccomp: 比较二个高精确度数字。
bcdiv: 将二个高精确度数字相除。
bcmod: 取得高精确度数字的余数。
bcmul: 将二个高精确度数字相乘。
bcpow: 求一高精确度数字次方值。
bcscale: 配置程序中所有 BC 函数库的默认小数点位数。
bcsqrt: 求一高精确度数字的平方根。
bcsub: 将二个高精确度数字相减。
posted @ 2017-03-24 16:40  zhongJaywang  阅读(612)  评论(0编辑  收藏  举报