精度运算类型BigDeciaml使用情况介绍

2022-07-29,,,,

简介

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

《精度运算类型BigDeciaml使用情况介绍.doc》

下载本文的Word格式文档,以方便收藏与打印。