在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的。