java处理浮点数精度

在使用浮点数过程中,必须考虑到精度问题
java使用Double类型进行计算时,会出现数值不够精确的情况

如:

 Double a1 = 5.1;
 Double b1 = 4.9;
 System.out.println(a1-b1);

运行结果:
在这里插入图片描述
与期待的结果有了一定的偏差。因为计算机是以二进制存储数据的,无法精确的表示浮点数。
要进行精确的浮点数计算需要使用BigDecimal类型

//        方法1:
        BigDecimal c = BigDecimal.valueOf(5.1);
        BigDecimal d = BigDecimal.valueOf(4.9);
        System.out.println(c.subtract(d));
        
//        方法2:
        BigDecimal c2 = new BigDecimal("5.1");
        BigDecimal d2 = new BigDecimal("4.9");
        System.out.println(c2.subtract(d2));

运行结果:
在这里插入图片描述
方法1中,BigDecimal.valueOf方法底层通过Double.toString将数值转换成String类型,然后同方法2一样,使用String值创建对象返回。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值