• 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 等语言中也会遇到同样的问题。
    解决方法:需要将其控制在我们需要的精度范围内再行比较。
    因此使用 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)
     
     

  • 相关阅读:
    CF700C Break Up
    CF865C Gotta Go Fast
    CF1559D2 Mocha and Diana (Hard Version)
    CF1500C Matrix Sorting
    排列计数机
    CSP-S 2021 退役记
    【做题记录】[NOIP2011 提高组] 观光公交
    【做题记录】构造题
    乱搞
    二维树状数组
  • 原文地址:https://www.cnblogs.com/rxbook/p/11402224.html
Copyright © 2020-2023  润新知