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

 

转载于:https://www.cnblogs.com/1020182600HENG/p/5859157.html

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值