zoukankan      html  css  js  c++  java
  • 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: 将二个高精确度数字相减。
  • 相关阅读:
    Leetcode424. 替换后的最长重复字符
    Leetcode82. 删除排序链表中的重复元素 II
    python 无序模块,hashlib模块
    python 内置方法
    python 面向对象的三大特性
    python 面向对象
    python 递归函数和二分查找
    python 装饰器
    python 函数名,闭包
    python 函数进阶
  • 原文地址:https://www.cnblogs.com/zhongJaywang/p/6612204.html
Copyright © 2011-2022 走看看