php浮点数的比较
2013-01-23 14:10
344 查看
PHP手册对于浮点数有以下警告信息:
Warning
浮点数精度 显然简单的十进制分数如同 0.1 或 0.7 不能在不丢失一点点精度的情况下转换为内部二进制的格式。这就会造成混乱的结果:例如,floor((0.1+0.7)*10)
通常会返回 7 而不是预期中的 8,因为该结果内部的表示其实是类似 ...。
这和一个事实有关,那就是不可能精确的用有限位数表达某些十进制分数。例如,十进制的
1/3 变成了 . . .。
所以永远不要相信浮点数结果精确到了最后一位,也永远不要比较两个浮点数是否相等。
另外,如果实在想比较两个float是否相等,也是有办法的。
方法一:使用bccomp(参数1,参数2,小数位)来比较。
方法二:如果不支持bcXXX扩展函数,可以使用下面的函数来做,经常用,屡试不爽。
最后附赠两个相关的有用函数:
Warning
浮点数精度 显然简单的十进制分数如同 0.1 或 0.7 不能在不丢失一点点精度的情况下转换为内部二进制的格式。这就会造成混乱的结果:例如,floor((0.1+0.7)*10)
通常会返回 7 而不是预期中的 8,因为该结果内部的表示其实是类似 ...。
这和一个事实有关,那就是不可能精确的用有限位数表达某些十进制分数。例如,十进制的
1/3 变成了 . . .。
所以永远不要相信浮点数结果精确到了最后一位,也永远不要比较两个浮点数是否相等。
另外,如果实在想比较两个float是否相等,也是有办法的。
方法一:使用bccomp(参数1,参数2,小数位)来比较。
$a = 0.23; $b = 1 - 0.77; var_dump($a); var_dump($b); var_dump(bccomp($a,$b,2); //OUTPUT float(0.23) float(0.23) bool(0) // 0表示两个浮点数值相等
方法二:如果不支持bcXXX扩展函数,可以使用下面的函数来做,经常用,屡试不爽。
function floatcmp($f1,$f2,$precision = 10) {// are 2 floats equal $e = pow(10,$precision); $i1 = intval($f1 * $e); $i2 = intval($f2 * $e); return ($i1 == $i2); }
最后附赠两个相关的有用函数:
function floatgtr($big,$small,$precision = 10) {// is one float bigger than another $e = pow(10,$precision); $ibig = intval($big * $e); $ismall = intval($small * $e); return ($ibig > $ismall); } function floatgtre($big,$small,$precision = 10) {// is on float bigger or equal to another $e = pow(10,$precision); $ibig = intval($big * $e); $ismall = intval($small * $e); return ($ibig >= $ismall); }
相关文章推荐
- PHP中两个float(浮点数)比较实例分析
- PHP浮点数比较
- php浮点数计算比较及取整不准确解决方法
- PHP浮点数比较
- php浮点数的比较
- php浮点数比较
- php浮点数计算比较及取整不准确解决方法
- PHP中两个float(浮点数)比较实例分析
- PHP浮点数比较
- php浮点数计算比较及取整不准确解决方法
- 浮点数比较大小
- PHP实现时间比较和时间差计算的方法示例
- 比较php中的各种排序函数
- 关于浮点数的比较以及提供精确的浮点数比较算法
- php中使用mysql、mysqli、pdo的比较
- 白刃之战:PHP vs. ASP.NET(节选)-架构比较
- for、while、foreach性能比较-PHP篇
- 浮点数的比较
- php与asp.net的性能比较
- php 求二维数组的差集|比较二维数组的不同 array_diff