用BigDecimal计算金额就高枕无忧了?带你了解BigDecimal这五个坑

开发 前端
一般情况下,对于不需要准确精度的计算,我们可以通过float或者double进行计算,但是如果需要精确计算的结果,就必须使用BigDecimal类来操作。

BigDecimal是java.math包中提供的API类,专门用于对超过16位有效位的数进行精确的运算。一般情况下,对于不需要准确精度的计算,我们可以通过float或者double进行计算,但是如果需要精确计算的结果,就必须使用BigDecimal类来操作。

而BigDecamal本质上是一个对象,所以传统的+、-、*、/等算术运算符就不能直接使用了。

今天我们来了解一下,使用BigDecimal时容易踩的五个坑。

1、错误的初始化

BigDecimal提供了很多初始化方法,但是需要注意的是,当我们使用double这种浮点型初始化,可能得到预期外的结果。

当我们使用浮点型进行初始化时,由于其本身就是一个不确定的值,传给BigDecimal初始化时已经丢失了精度,所以看起来就像一个bug。

一般来说,建议大家初始化时将其转为String或者使用BigDecimal.valueOf方法。

2、错误的等值比较方法

equal方法会比较两个BigDecimal对象的精度,如果精度不同,则认为是两个不同的对象。

如果要比较两个对象的大小,建议使用compareTo方法。

3、未指定精度可能会导致异常

如果除法的商是一个无限小数,而我们又没有指定精度大小,程序将抛出一个异常。当我们使用BigDecimal时,应该时刻记得指定精度,避免因为精度问题带来的损失。

4、toString方法的格式问题

当我们想把一个BigDecimal.valueOf构造的BigDecimal转为String时,应该了解到toString方法和toPlainString方法的区别。

toString:必要时会使用科学计数法。

toPlainString:不使用科学计数法。

toEngineeringString:工程计算中经常使用的记录数字的方法,与科学计数法类似,但要求10的幂必须是3的倍数。

5、执行顺序不同导致的结果差异

当执行算术运算时,会满足乘法交换律,但是对于BigDecimal来说,是不适用的。

不同的执行顺序会得到不同的结果,对于金融类的需求,这0.1的差额,足够你排除bug到半夜了。

总结

1、BigDecimal虽然计算精度准确,但是其性能相对double,float是较差的。如果没有高精度计算的要求,那也不必强行使用BigDecimal。

2、初始BigDecimal时,建议强制使用字符串的构造参数。

3、BigDecimal对象是不可变的,每次计算都会产生一个新对象,所以记得保存做完计算以后的值。

责任编辑:姜华 来源: 今日头条
相关推荐

2024-04-10 08:39:56

BigDecimal浮点数二进制

2010-03-17 14:38:02

2010-09-02 17:22:34

DHCP服务器

2013-07-18 15:57:42

2017-05-03 17:49:33

CIO云计算异构

2023-06-30 08:10:14

JavaBigDecimal

2010-01-27 16:17:57

2009-07-09 15:43:26

2017-05-15 08:43:34

半月刊

2021-02-02 11:13:41

BigDecimal支付电商

2022-02-17 16:34:33

戴尔

2024-04-15 00:00:00

LongBigDecimal运算

2011-05-06 10:44:10

惠普激光打印机

2022-07-19 07:30:06

BigDecimal运算float

2018-01-07 01:32:31

2020-03-02 14:55:02

JavaBigDecimalAPI

2022-12-08 09:34:26

开发操作

2011-11-23 13:04:19

Java高精度BigDecimal

2023-04-07 17:19:04

2009-10-23 14:46:43

点赞
收藏

51CTO技术栈公众号