在日常开发中我们经常会碰到小数计算,而小数直接计算的话会出现一些小小的错误,如下

java 判断bigdecimal精度(为什么要使用BigDecimal类型进行高精度运算)(1)

你说能输出什么?3.03?实际上输出的是3.0300000000000002。这是因为不论是float 还是Double都是浮点数,而计算机是二进制的,浮点数会失去一定的精确度。有没有不失精度的办法呢?这里就要用到BigDecimal了。

java.math.BigDecimal。Java在java.math包中提供的API类BigDecimal,用来对超过16位有效位的数进行精确的运算。双精度浮点型变量double可以处理16位有效数。在实际应用中,需要对更大或者更小的数进行运算和处理。float和double只能用来做科学计算或者是工程计算,在商业计算中要用java.math.BigDecimal。BigDecimal所创建的是对象,我们不能使用传统的 、-、*、/等算术运算符直接对其对象进行数学运算,而必须调用其相对应的方法。方法中的参数也必须是BigDecimal的对象。构造器是类的特殊方法,专门用来创建对象,特别是带有参数的对象。

创建BigDecimal对象主要有两种。

java 判断bigdecimal精度(为什么要使用BigDecimal类型进行高精度运算)(2)

其中b1也可以写成new BigDecimal(Double.toString(1.34)),可以直接new BigDecimal(1.34)吗,也是可以的,只是会出现上述的精度问题。

java 判断bigdecimal精度(为什么要使用BigDecimal类型进行高精度运算)(3)

除了这两种外,特殊的像0、1、10可以这样写。

java 判断bigdecimal精度(为什么要使用BigDecimal类型进行高精度运算)(4)

,