java string 精度_关于Java计算精度问题

初级问题:

double i = 399 * 0.075;

此时结果:29.924999999999997 明显和我们应得的29.925有精度上的问题

so,马上想到了BigDecimal这一高精度计算专用的类

new BigDecimal(399).multiply(new BigDecimal(0.075)).doubleValue();

此时结果:29.924999999999997,说好的高精度计算呢

后发现

Note: the results of this constructor can be somewhat unpredictable. One might assume that new BigDecimal(.1) is exactly equal to .1, but it is actually equal to .1000000000000000055511151231257827021181583404541015625. This is so because .1 cannot be represented exactly as a double (or, for that matter, as a binary fraction of any finite length). Thus, the long value that is being passed in to the constructor is not exactly equal to .1, appearances nonwithstanding. The (String) constructor, on the other hand, is perfectly predictable: new BigDecimal(“.1”) is exactly equal to .1, as one would expect. Therefore, it is generally recommended that the (String) constructor be used in preference to this one.

即构造参数传入double时奇数转换二进制还是存在精度问题,而string就完全ok

最终

`new BigDecimal(399).multiply(new BigDecimal("0.075")).doubleValue();

得到预知结果

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值