美文网首页
为什么在java中涉及到钱的计算,我推荐用BigDecimal,

为什么在java中涉及到钱的计算,我推荐用BigDecimal,

作者: 易海峰 | 来源:发表于2017-12-04 23:32 被阅读0次

    在java中,用什么类型处理小数,一般下意识会想到float和double。

    首先,为什么是这两个呢?

    1.好用,单词写起来简单,记也好记,拼读发音也不容易错。

    float  f = 1.1f;

    double d = 1.2f;

    2.四折运算(加减乘除)简单

    float f1 = 1.2f;

    float f2 = 1.3f;

    float f3 = f2 - f1;  

    System.out.println(f3); //0.099999905


    double d1 = 1.2f;

    double d2 = 1.3f;

    double d3= d2 - d1;

    System.out.println(f3); //0.09999990463256836


    再来看看BigDecimail,首先名字忒长,接着看看用法。

    BigDecimail b1= new BigDecimail("1.2");

    BigDecimail b1= new BigDecimail("1.3");  //怕写错,直接复制上面的,只将2改成了3,为什么这里1.3 变成了“1.3”?

                                                                             //因为编译器二进制无法精确地表示十进制小数1.3,当它读到1.3时,会将1.3                                                                         //用8个字节的double值表示,可能你打印输出变成了                                                                                                                      //1.3000000000000000444089209850062616169452667236328125

    BigDecimail b3 = b2.subtract(b1) ;//

    b3.setScale(1,RoundingMode.HALF_UP);

    System.out.println(b3);   //0.1

    至此,应该看到了最大的问题吧。精度不一样,可能会造成很大的问题。1和0.99  都乘以1000  就相差了10,BigDecimail 可以有好几种定义精度的模式。而且值按道理是可以无限大的。由于BigDecimail性能肯定比不了int和long, 在小范围的值可以用int,long 来替换(*1000 之类的后面再除)。但是超过18位,就一定要用BigDecimail。当然咯,如果对值的精确要求不是特别高,还是可以使用float和double的。

    相关文章

      网友评论

          本文标题:为什么在java中涉及到钱的计算,我推荐用BigDecimal,

          本文链接:https://www.haomeiwen.com/subject/bkwfixtx.html