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

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

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)

,

免责声明:本文仅代表文章作者的个人观点,与本站无关。其原创性、真实性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容文字的真实性、完整性和原创性本站不作任何保证或承诺,请读者仅作参考,并自行核实相关内容。文章投诉邮箱:anhduc.ph@yahoo.com

    分享
    投诉
    首页