JAVA解惑--找零时刻

问题:下述程序能否得到你想要的结果

System.out.println(2.00-1.10);  //结果为0.8999999999999999

从结果可知,并没有得到想要的结果0.90.

原因是1.1这个数字不能被精确表示为一个double,而是被表示为最接近它的double值,从而参与运算的是最接近的double值,而非1.1。

一般的,并不是所有的小数都可以用二进制浮点数精确表示。

浮点运算在一个范围很广的值域上提供了很好的近似,但通常不能产生精确的结果。

解决方案:

使用执行精确运算的BigDecimal

但是要用

BigDecimal(String val) 将 BigDecimal 的字符串表示形式转换为 BigDecimal。

而不是

BigDecimal(double val)    将 double 转换为 BigDecimal,后者是 double 的二进制浮点值准确的十进制表示形式。

看如下程序:

System.out.println(new BigDecimal("2.0").subtract(new BigDecimal("1.10")));
System.out.println(new BigDecimal(2.0).subtract(new BigDecimal(1.10)));

结果分别为:

0.90
0.899999999999999911182158029987476766109466552734375

从而可以看出要使用第一个构造器。

所以,涉及到精度要求很高的时候,要使用BigDecimal等解决方案。



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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值