java中如果需要精确的计算答案,请避免使用double类型与float类型

mac2022-06-30  72

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上百实例源码以及开源项目
最新回复(0)