BigDecima作用及原理
- BigDecimal:表示不可变的,任意精度的有符号十进制数
- 作用:
- 用于小数的精确计算(解决小数运算精度失真问题)
- 用于表示很大的小数
- BigDecimal继承结构:
java.lang.Object
<=继承=java.lang.Number
<=继承=java.math.BigDecimal
- 创建实例对象:
//通过传递长整型表示的小数来创建对象 //有一定不可预知性,得到的结果可能不精确,源码中直接将double类型转换为String类型,再调用传递String类型的构造方法。 BigDecimal bd1 = new BigDecimal(1.236); //通过传递字符串表示的小数来创建对象 BigDecimal bd2 = new BigDecimal("1.229"); //通过静态方法获取对象(不能超过double范围) BigDecimal bd3 = BigDecimal.valueOf(10); /* 1. 如果要表示的数字不大,没有超出double取值范围,建议使用静态方法。 2. 如果要表示的数字比较大,超出double取值范围,建议使用构造方法。 3.使用静态方法时,当我们传递的是0~10范围的整数,方法返回创建好的对象,不会重新new。 */
- 常用方法:
public static BigDecimal valueOf(val)
:获取实例对象public BigDecimal add(BigDecimal val)
:加法public BigDecimal subtract(BigDecimal val)
:减public BigDecimal multiply(BigDecimal val)
:乘public BigDecimal divide(BigDecimal val)
:除public BigDecimal divide(BigDecimal val,精准几位,舍入模式)
:除
- 舍入模式,使用
RoundingMode
类中的枚举常量,常用RoundingMode.HALF_UP四舍五入。
- 底层存储方式:
- 创建实例时构造方法或静态方法传入的数据会转换为字符串String。
- 扫描字符串每个字符,存储成字符数组char[]。
- 字符数组中的每一个元素都转换为对应的ASCII码存储进byte[]。