float、double计算中精度丢失的处理

参考http://blog.csdn.net/luweicheng24/article/details/77800688

import java.math.BigDecimal;


public class T {
public static void main(String[] args) {
    String aaString="37.10";
    System.err.println(Double.valueOf(aaString));
    System.err.println(Float.valueOf(aaString));

    float amount =37.10f;
    float amount2 =amount*100;
    float amount4 =amount*100f;
    long amount3 =(long)amount2;

    System.err.println(amount);
    System.err.println(amount2);
    System.err.println(amount3);
    System.err.println(amount4);



//  
    BigDecimal bigDecimal1 = new BigDecimal(Float.toString(amount));
    System.err.println(bigDecimal1);
    BigDecimal bigDecimal2 = new BigDecimal(Float.toString(100));
    System.err.println(bigDecimal2);

    BigDecimal result = bigDecimal1.multiply(bigDecimal2);
    System.err.println(result);

    long longValue =result.longValue();

    System.err.println(longValue);


}
}

37.1
37.1
37.1
3709.9998
3709
3709.9998
37.1
100.0
3710.00
3710

1、String 转 float不会丢失精度;
2float乘法计算会丢失精度、
乘积总是在一个正确的结果左右偏0.0000**1,这是因为当两个float数值相乘时,底层采用转换成二进制来进行乘法的运算
3、采用BigDecimal 可以实现高精度运算
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值