使用BigDecimal可避免浮点精度问题,推荐字符串构造如new BigDecimal("0.1"),运算通过add、subtract等方法实现,除法需指定精度和舍入模式,比较应使用compareTo而非equals或==。
在Java中进行精确的小数计算时,Bi
gDecimal 是最常用且推荐的类。它能避免浮点数运算中的精度丢失问题,特别适用于金融、货币等对精度要求高的场景。
为了避免构造方法 new BigDecimal(double) 带来的精度问题,应优先使用字符串构造函数:
BigDecimal是不可变对象,所有操作都会返回新的实例,原对象不变:
例如:
BigDecimal result = a.divide(b, 2, RoundingMode.HALF_UP);
表示保留两位小数,四舍五入。
不能使用 == 或 equals() 判断数值相等(equals会比较scale),应使用 compareTo():
若要判断值相等,建议用:a.compareTo(new BigDecimal("0")) == 0
在做除法或需要控制小数位数时,必须设置scale(小数位数)和RoundingMode:
示例:
result = a.divide(b, 4, RoundingMode.HALF_UP); // 保留4位,四舍五入