double类型与float类型主要用于科学计算与工程计算而设计的,用于二进制浮点计算。对于普通计算通常是结果不准确的,所以对于普通的浮点数的加减法等,解决的方法需要用int,long,BigDecimal来计算。
1.计算出现的问题?
计算结果如下:
显然结果不是我们所需要的。我们需要的结果是:0.88
所以,我们的程序应该这样写:
1 public static void main(String[] args) {
2 BigDecimal a=BigDecimal.valueOf(1.29
);
3 BigDecimal b=BigDecimal.valueOf(0.41
);
4 System.out.println(a.subtract(b));
5 }
最后的结果也是我们需要的结果:
循环计算:
public static void main(String[] args) {
BigDecimal a=
new BigDecimal(0.00
);
BigDecimal b=
null;
for(
int i=0;i<4;i++
){
b=BigDecimal.valueOf(5.7+
i);
a=
a.add(b);
}
System.out.println(a);
}
运行结果为:28.8 嘿嘿,浮点类型终于可以比较准确的计算了
这又长见识了。。。
转载于:https://www.cnblogs.com/huzi007/p/4091942.html
相关资源:JAVA上百实例源码以及开源项目