美文网首页
PHP浮点数运算不准确的问题(转)

PHP浮点数运算不准确的问题(转)

作者: haoxg | 来源:发表于2019-06-05 09:07 被阅读0次
echo intval(0.58*100);//结果为57

echo intval((0.1 + 0.7) * 10);//结果为7

产生这样的原因是计算机内部对部分浮点数不能准确地用二进制表示,就像我们不能用十进制准确表示10/3一样.

浮点数在计算机内部的表示:IEEE 754.不懂的自己查找资料

也可以参考一下鸟哥这篇文章:http://www.laruence.com/2013/03/26/2884.html

<?php
echo intval(0.58*100);  //57,注意啦
echo '<br/>';
echo intval(bcmul(0.58, 100));  //58
echo '<br/>';
echo floor(strval(0.58*100));   //58
echo '<br/>';
echo (int)(0.58 * 1000/10); //58
echo '<br/>';
echo intval((0.1 + 0.7) * 10);  //7,注意啦
echo '<br/>';
echo intval(bcadd("0.1", "0.7",1) * 10);  //8
?>
再看一个例子

<?php
if((0.1 + 0.7) == 0.8){
    echo '相等'; 
}else{
    echo '不相等'; //这里输出
}
echo '<br />';
$a = 0.1 + 0.7;
echo $a; //0.8
echo '<br/>';
if($a == 0.8){ 
    echo '一天一小步';
}else{
    echo '一年一大步'; //这里输出
}
echo '<br/>';
if(strval($a) == 0.8){
    echo '一天一小步'; //这里输出
}else{
    echo '一年一大步'; 
}
echo '<br/>';
if(bcadd(0.1, 0.7,1) == 0.8){
    echo '一天一小步'; //这里输出
}else{
    echo '一年一大步';
}
    /*
    结果:
    不相等
    0.8
    一年一大步
    一天一小步
    一天一小步
    */
$a = 0.00...00(n个0)1 + 0.7;//用strval对$a进行取值的时候,会因为n个0的个数不同,导致$a和0.8是否相等的结果不同,而bcadd函数会对2个数相加,根据你选择保留几个小数,而舍弃后面的小数

?>

看个除法例子:

<?php
echo 160500643816367088/10;//1.6050064381637E+16
echo '<br/>';
echo intval(160500643816367088/10);//16050064381636710
echo '<br/>';
echo bcdiv(160500643816367088,10);//16050064381636708
?>

所以对于浮点数来计算金额这些敏感的数据,推荐使用PHP的BC函数

BCMath 任意精度数学
bcadd — 2个任意精度数字的加法计算
bccomp — 比较两个任意精度的数字
bcdiv — 2个任意精度的数字除法计算
bcmod — 对一个任意精度数字取模
bcmul — 2个任意精度数字乘法计算
bcpow — 任意精度数字的乘方
bcpowmod — Raise an arbitrary precision number to another, reduced by a specified modulus
bcscale — 设置所有bc数学函数的默认小数点保留位数
bcsqrt — 任意精度数字的二次方根
bcsub — 2个任意精度数字的减法

原文:https://blog.csdn.net/weixin_37909391/article/details/80911087

相关文章

  • PHP浮点数运算不准确的问题(转)

    产生这样的原因是计算机内部对部分浮点数不能准确地用二进制表示,就像我们不能用十进制准确表示10/3一样. 浮点数在...

  • 22.系统的讲解 - PHP 浮点数高精度运算

    转发地址:系统的讲解 - PHP 浮点数高精度运算

  • js浮点运算

    前言 在项目开发过程中发现浮点数的运算会出现精度问题,尤其是乘除运算。产生浮点数计算精度不准确的原因: 在计算机角...

  • Javascript 盲点

    1.javestript 中所有的数字都是浮点型 js在浮点数运算时会出现多位小数的不准确结果,浮点数运算的误差。...

  • iOS开发浮点数计算精度问题

    1、浮点数运算带来的问题 在日常工作中涉及到浮点数(float、double)的运算 2、浮点数运算精度的解决方案...

  • Python浮点数精度损失问题

    浮点数误差浮点数一个普遍的问题就是在计算机的世界中,浮点数并不能准确地表示十进制。并且,即便是最简单的数学运算,也...

  • python 浮点数精确运算解决方案 !

    浮点数误差 浮点数一个普遍的问题就是在计算机的世界中,浮点数并不能准确地表示十进制。并且,即便是最简单的数学运算,...

  • js浮点数运算问题---莫名出现多位小数

    问题:js浮点数运算问题---莫名出现多位小数 // 原因:这是由于在运算的时候先把浮点数转化成二进制后进行运算,...

  • php 浮点数运算

    比较 相加 相减 相除 相乘 设置小数点

  • javaScript-02

    运算符 算数运算符 概念:算术运算使用的符号,用于执行两个变量或值的算术运算。 浮点数的精度问题浮点数值的最高精度...

网友评论

      本文标题:PHP浮点数运算不准确的问题(转)

      本文链接:https://www.haomeiwen.com/subject/refjxctx.html