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

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  嘿嘿,浮点类型终于可以比较准确的计算了

 

这又长见识了。。。

  

 

posted @ 2014-11-12 12:54  全力以赴001  阅读(3055)  评论(0编辑  收藏  举报