本文主要是介绍BigDecimal使用注意的地方,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
BigDecimal
是 Java 中的一个类,这个相信大家都是知道的。它的作用就是可以表示任意精度的十进制数,BigDecimal
提供了精确的数字运算,适用于需要高精度计算的场景。
一、浮点精度
我们先来看一个例子:
public static void main(String[] args) {BigDecimal num1 = new BigDecimal("0.1");BigDecimal num2 = new BigDecimal("0.10");// falseSystem.out.println(num1.equals(num2));// 0System.out.println(num1.compareTo(num2));}
compareTo 方法比较中,a.compareTo(b)
返回:
-1: a小于b
0: a等于b
1: a大于b。
在上方的代码中,我们使用 new BigDecimal
的形式 new 了两个 BigDecimal
对象,分别是 0.1
和0.10
。
我们分别使用了 equals
与 compareTo
进行比较,当使用 equals
进行比较时,返回了 false
,这是因为 equals
不仅比较了值是否相等,还比较了精度是否相等。
简单概括一下,如果比较两个 BigDecimal
对象的大小,那就使用 compareTo
方法;如果严格比较精度的大小,那就使用 equals
方法进行比较。
二、设置精度
在做 BigDecimal
对象计算的时候,一定要设置精度。
public static void main(String[] args) {BigDecimal num1 = new BigDecimal("1");BigDecimal num2 = new BigDecimal("3");BigDecimal result = num1.divide(num2); // 默认舍入模式为 UNNECESSARY,会抛出 ArithmeticException}
在做 divide
运算时,如果商是一个无限小数,而操作的结果是一个精确的数字,那么就会抛出该异常。
三、初始化
先来看代码:
BigDecimal num = new BigDecimal(0.1); // 使用双精度浮点数构造
System.out.println(num); // 输出: 0.1000000000000000055511151231257827021181583404541015625BigDecimal num2 = new BigDecimal("0.1"); // 使用字符串构造
System.out.println(num2); // 输出: 0.1
在使用 new BigDecimal
构造器进行初始化的时候,如果有初始值,最好使用字符串的构造方法进行初始化。
在使用 double
的构造器进行新建时,本身传入的 0.1
就是浮点类型了,为了不丢失精度,在使用 new BigDecimal
新建时就把这个近似值完整的保留下来了。
或者就是 另外一种初始化方式 BigDecimal.valueOf(0.1);
,通过看源码可以发现,在 valueOf
的内部,将 Double
类型直接转为了字符串了,因此也就不会存在精度丢失的问题了。
四、转字符串
还是先看一段代码:
public static void main(String[] args) {BigDecimal a = BigDecimal.valueOf(89382389312389594.33822312317952678768725);System.out.println(a.toString()); // 输出:8.93823893123896E+16String str = a.setScale(2, RoundingMode.HALF_UP).toString();System.out.println(str); // 输出: 89382389312389600.00}
上面代码中是一个非常大的数,我想把他转为字符串,可是在使用 toString()
方法时,打印出来的却是科学计数法。
所以如果想使用 toString()
方法进行转字符串时,可以使用设置精度的方法,但是结果还是与我们的预期有所差别,我们想要的是一模一样的打印出来呢?
那么 toPlainString
就上场了,这个方法返回一个字符串的表示形式,包含所有的有效数字。
代码修改如下:
public static void main(String[] args) {BigDecimal a = new BigDecimal("89382389312389594.99933822312317952678768725");System.out.println(a.toPlainString());}
所以总结就是
toString
:返回有效数字,必要的时候使用科学计数法。toPlainString
: 不实用任何科学计数法。toEngineeringString
:必要的时候使用工程计数法。
这篇关于BigDecimal使用注意的地方的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!