我的同事做了这个实验:
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