zoukankan      html  css  js  c++  java
  • 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();

           除法运算:

           //scale表示指定保留几位小数,若发生除不尽的情况,则按四舍五入来保留小数

           double   div=b1.divide(b2,scale,BigDecimal.ROUND_HALF_UP).doubleValue();

           只保留小数位数的两种方法:

           1)double num1=b1.divide(1,scale,BigDecimal.ROUND_HALF_UP).doubleValue();     

           2)BigDecimal bg=new BigDecimal(d1);

              double num2=bg.setScale(scale,BigDecimal.ROUND_HALF_UP).douleValue();

           3)DecimalFormat bg=new DecimalFormat("###0.00");

             double num3=bg.format(d1);

           4)String num4=String.format("%.2f",d1);//与C语言的打印输出类似

              String num5=String.format("%.2f,%.3f,%.3f",d1,d1,d3); 

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

  • 相关阅读:
    ceph 高可用部署
    ceph安装
    openstack 命令
    ceph
    go test 怎么做测试
    govendor
    wrap 缓存。。。
    python中if __name__ == '__main__': 的解析
    pythton 字典的使用,字典的方法
    python 基础 如何让程序接收参数,最简单用sys.argv[]来获取
  • 原文地址:https://www.cnblogs.com/1020182600HENG/p/5859157.html
Copyright © 2011-2022 走看看