深入理解BigDecimal

为什么要使用BigDecimal? 

我想只要是从事过JAVA金融产品研发工作的同学对于BigDecimal就一定不会陌生。但同学们是否想过为什么要用BigDecimal数据类型,是否可以直接使用单精度或者双精浮点数来表示金额信息?答案肯定是不可以的,用一句话来解释就是:十进制的小数在转化成二进制浮点数时会产生精度问题,例如:0.3转化成二进制(转化方法自行问百度)。

BigDecimal的底层数据结构使什么?它是怎么保证精度的?

这曾经是一道阿里巴巴的面试题,由于在工作中使用最多的是BigDecimal的加、减、乘、除的的方法,还真没想过它的实现原理(完全是拿来主义惹的祸),乍这么一问还真有点懵。BigDecimal保证精度的解决思路其实极其的简单朴素,还是用一句话来解释:十进制整数在转化成二进制数时不会有精度问题,那么把十进制小数扩大N倍让它在整数的维度上进行计算,并保留相应的精度信息

深入理解BigDecimal_第1张图片

请大家注意

MySql中的统计函数:sum()、avg()等等,给JAVA应用默认返回的是Double类型!在处理小数的时候可能产生精度问题,此时把预处理的字段数据用cast强转成decimal类型,那么MySql给JAVA应用返回的就是BigDecimal类型。

 

你可能感兴趣的:(深入理解BigDecimal)