java减法运算精度问题_java – 双减法精度问题

我的同事做了这个实验:

public class DoubleDemo {

public static void main(String[] args) {

double a = 1.435;

double b = 1.43;

double c = a - b;

System.out.println(c);

}

}

对于这个一年级的操作,我期望这个输出:

0.005

但出乎意料的是输出是:

0.0050000000000001155

为什么在这么简单的操作中双重失败?如果double不是这项工作的数据类型,我应该使用什么?

解决方法:

double在内部存储为二进制的分数 – 如1/4 1/8 1/16 …

值0.005 – 或值1.435 – 不能以二进制形式存储为精确分数,因此double不能存储精确值0.005,并且减去的值不是很精确.

如果您关心精确的十进制算术,请使用BigDecimal.

您还可以找到this article有用的阅读材料.

标签:java,double

来源: https://codeday.me/bug/20190926/1821916.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值