在项目中经常遇到定义成Double类型的数据,在遇到乘除计算上出现“精度损失”的问题,满足不了硬性需求。建议使用BigDecimal 类型
BigDecimal payableMoney = new BigDecimal("0") 定义一个新的BigDecimal 对象,值为0
其中BigDecimal 在处理小数点上有很方便的方法 .setScale
BigDecimal.setScale()方法用于格式化
以下是项目中计算电费金额的代码 关于BigDecimal的使用
1 BigDecimal actEleDegree = new BigDecimal(actEleDegrees); 2 actEleDegree = actEleDegree.setScale(2, BigDecimal.ROUND_HALF_UP); 3 BigDecimal payableMoneys = unitPrices.multiply(actEleDegree);
第二行:实际电量 格式为保留两位小数,四舍五入向上舍入(1.885-》1.89) 若为 BigDecimal.ROUND_HALF_DOWN,为四舍五入向下舍入(1.885-》1.88)
第三行: multiply方法 两边对象的数据进行相乘 ,需均为BigDecimal对象
另外还有两种模式 均为保留两位小数
BigDecimal.ROUND_UP 直接向上进位 (1.885-》1.89)(1.881-》1.89)
BigDecimal.ROUND_DOWN 直接保留小数位 (1.885-》1.88)(1.887-》1.88)