精度运算类型BigDeciaml使用情况介绍
简介
float和double不能进行精确的浮点运算,Java提供了一种能够进行精度运算的类型java.math.BigDecimal
。
BigDecimal初始化
构造方法
BigDecimal提供了重载的构造方法。可以根据传入的参数创建一个BigDecimal类型对象。这个参数可以是String,double,int,long等。还可以在创建对象的时候指定精度。通过double创建对象的时候,因为浮点数在二进制表示中本身的限制,可能会出现不可预测的结果。
System.out.println(new BigDecimal(12.3456789)); System.out.println(new BigDecimal("12.3456789"));
上面两条语句的运行结果并不相同:
12.345678899999999345027390518225729465484619140625
12.3456789
所以,初始化BigDecimal的时候应该使用BigDecimal(String val)
而不是BigDecimal(double val)
。如果参数类型是double,可以使用BigDecimal(Double.toString(val))
。比如下面的代码:
public static void main(String[] args) { double d = 12.3456789; BigDecimal dec = new BigDecimal(Double.toString(d)); System.out.println(dec); }
valueOf 方法
还有一种创建BigDecimal的方法,就是通过valueOf方法。
valueOf是一个静态方法。可以规避上面提到的使用浮点数时不可预测的情况。比如:
import java.math.BigDecimal; public class Demo { public static void main(String[] args) { System.out.println(new BigDecimal(12.3456789)); System.out.println(BigDecimal.valueOf(12.3456789)); } } // 12.345678899999999345027390518225729465484619140625 // 12.3456789
BigDecimal四则运算
BigDecimal是对象类型,不能使用运算符进行四则运算,而是由BigDecimal类本身提供了BigDecimal add(BigDecimal augend)
,BigDecimal subtract(BigDecimal subtrahend)
,BigDecimal multiply(BigDecimal multiplicand)
,BigDecimal divide(BigDecimal divisor)
四个方法。
import java.math.BigDecimal; public class Demo { public static void main(String[] args) { BigDecimal num1 = new BigDecimal("5"); BigDecimal num2 = new BigDecimal("2"); System.out.println(num1.add(num2)); System.out.println(num1.subtract(num2)); System.out.println(num1.multiply(num2)); System.out.println(num1.divide(num2)); } }
BigDecimal判等
总所周知,BigDecimal 是对象类型,所以判等操作不应该使用==
。如果需要进行等值判断,推荐使用 compareTo
方法而不是 equals
。
BigDecimal同样也重写了equals
方法,但是equals
方法比较的是值(value)和精度(scale)两个部分,在使用String类型的参数初始化BigDecimal时,就会产生于实际不符的情况,比如:
import java.math.BigDecimal; public class Demo { public static void main(String[] args) { BigDecimal num1 = new BigDecimal("1"); BigDecimal num2 = new BigDecimal("1.0"); System.out.println(num1.equals(num2)); } }
这里运行的结果是false
。因为num1和num2的精度不相同。精度在使用double类型参数初始化时因为浮点数本身的限制,会与预期有所不同,应该慎重使用。
compareTo
方法比较两个BigDecimal类型对象dec1.compareTo(dec2)
,如果对象数值相等返回0,如果dec1小于dec2返回-1,dec1大于dec2返回1。
与数据库对应关系
数据库中的 decimal 类型的字段映射到 POJO ,自动封装类型是 BigDecimal。
本文地址:https://blog.csdn.net/qq_38234015/article/details/108846601
推荐阅读