BigDecimal是开发中经常使用到的类,在涉及金额相关的字段时,精度要求是非常严格的,这也是不用double的原因了。没用过的开发者通常会遇到一个问题,就是**经过一通计算,没有得到预期的结果,得到的还是原来未参与运算的那个值。**通常大家看到最多的就是0。
这个问题我们从代码上来看是看不出来的,要想知道前因后果就需要看看BigDecimal的加,减,乘,除都是如何计算的,下面我们来看看BigDecimal源码吧!
通过乘法为例,上图中的BigDecimal multiply((BigDecimal multiplicand)(把整个方法都写出来是为了区别后面的同名方法)方法返回的结果是调用了另一个方法BigDecimal multiply(long x, long y, int scale),我们看下方的图可以发现,最终返回的结果是new了一个新的BigDecimal对象。也就是说使用BigDecimal的加减乘除方法时,需要重新接收一下计算的结果。
上面这段话有些人可能会理解,但是有些人估计还是蒙的。理解的就不用往下看了,不理解的看看下面的代码及运行结果:
示例中创建了一个BigDecimal对象,值为32。看第8行代码(就是大家出错的写法),这个时候我们期望输出的是32 * 2 = 64,偏偏运行结果是32。解释一下:第7行有一个BigDecimal对象,它的值是32;第8行一整行是一个BigDecimal对象(因为内部返回的结果是重新new的),这个对象没有名字。所以第9行输出的就是第7行的值。
接下来第10行就比较好理解了,我把32 * 2 的值赋值给了第7行声明的BigDecimal对象。第7行的值由32变成了64。
最后解释一下为什么大家看到最多的是0,原因是我们计算时大家都会先声明一个BigDecimal对象用于记录计算结果,一般初始化时大家给的值都是0,结合上面的示例就是大家初始化的时候不会写32,而是写0。所以测试时看到0居多。