double发生精度丢失的解决办法

Posted 奋斗的少年WH

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了double发生精度丢失的解决办法相关的知识,希望对你有一定的参考价值。

发生精度丢失的原因:

         个人理解:机器在运行时,使用2进制形式的计数方式,而我们日常生活中的计算是10进制的,对于整数的加减乘除,double还能适用,但是对于有小数的,则容易发生精度丢失,即用2进制表示10进制小数时,部分小数只是近似的表示,2进制表示不完全准确,此时,只能用BigDecimal来进行精确的精度计算。

       double  d1=5.0;

       double d2=4.9;

       BigDeciaml b1=new BigDeciaml(d1);

       BigDecimal b2=new BigDecimal(d2);

     

       加法运算:

       double sum=b1.add(b2).doubleValue();

       减法运算:

       double  sub=b1.subtract(b2).doubleValue();

       乘法运算:

       double   mul=b1.multiply(b2).doubleValue();

       除法运算:(还有些问题)

       double   div=div(b1,b2,DEF_DIV_SCALE);

             

      注意:doubleValue()  将此BigDecimal 转换为 double

 

以上是关于double发生精度丢失的解决办法的主要内容,如果未能解决你的问题,请参考以下文章

一篇文章带你深入探讨 DECIMAL 解决 MySQL 数据精度丢失问题

double 转换long 丢失精度

BigDecimal精度丢失问题

iOS数据解析精度丢失

java中两double相加精度丢失问题及解决方法

Spring Mvc Long类型传输到前端精度丢失