龙空技术网

「java」为什么要使用BigDecimal类型进行高精度运算

程序员界的彭于晏 2219

前言:

此时同学们对“高精度java”大概比较关怀,我们都需要剖析一些“高精度java”的相关资讯。那么小编在网上汇集了一些关于“高精度java””的相关资讯,希望姐妹们能喜欢,同学们一起来了解一下吧!

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

你说能输出什么?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对象主要有两种。

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

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

标签: #高精度java