• 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: 将二个高精确度数字相减。
  • 相关阅读:
    D3DPT_TRIANGLESTRIP 与 D3DPT_TRIANGLEFAN 的区别
    [转]DrawPrimitive 详解Direct3DDevice8
    sublime useful packages
    spring+freemarker 乱码解决办法
    vim 更改注释颜色
    git rollback
    从源码导入到github
    Laravel 安装
    Install Apache 2.2.15, MySQL 5.5.34 & PHP 5.5.4 on RHEL/CentOS 6.4/5.9 & Fedora 19-12 [转]
    Linux / Unix Command: rz
  • 原文地址:https://www.cnblogs.com/zhongJaywang/p/6612204.html
Copyright © 2020-2023  润新知