涉及结算系统,金额计算,对精确度要求比较高,Java中我们经常会用到BigDecimal来做处理
1为什么要用BigDecimal
2 BigDecimal如何使用
2.1 BigDecimal的构建
2.2 BigDecimal加减乘除
2.3 BigDecimal精度处理和舍入模式
1 为什么要用BigDecimal

第二种精度损失比第一种严重,如果在一些计算金额的项目中,优先选择第一种方案,所以金额计算中我们都推荐使用BigDecimal
2 BigDecimal如何使用
2.1 BigDecimal的构建
BigDecimal(int)
BigDecimal(long)
BigDecimal(String)//推荐使用
BigDecimal(Double)//不推荐使用
为什么BigDecimal(Double)不推荐使用呢,
用Double返回有明显的精度差
2.2 BigDecimal的加减乘除

2.3 BigDecimal精度处理和舍入模式
舍入模式有以下几种
1、ROUND_UP
2、ROUND_DOWN
3、ROUND_CEILING
4、ROUND_FLOOR
5、ROUND_HALF_UP 《4舍5入》
6、ROUND_HALF_DOWN
7、ROUND_HALF_EVEN《银行家算法》
8、ROUND_UNNECESSARY
比较常用的是ROUND_HALF_UP还有ROUND_HALF_EVEN
,一般我们在计算金额的时候,都会有个需求,是4舍5入精确到小数点2位
。BigDecimal提供了这样的接口
BigDecimal value2=new BigDecimal(“2.3”).setScale(2,BigDecimal.ROUND_UP);
通过setScel参数,第一个参是是精确到几位数,第二个是采用什么舍入模式
在处理金额计算,特别是结算系统中,精确度至关重要。Java的BigDecimal类用于解决浮点数计算引起的精度问题。本文将介绍BigDecimal的构造、基本运算及精度处理,包括舍入模式的使用。

1495

被折叠的 条评论
为什么被折叠?



