今天在看《阿里巴巴Java开发手册》中提到
浮点数之间的等值判断,基本数据类型不能用==来比较,包装数据类型不能用 equals 来判断
具体原理和浮点数的编码方式有关,这里就不多提了,我们下面直接上实例:
上面可以看到,出现进度缺失,一般我们常见的方式就是使用BigDecimal 来定义浮点数的值再进行浮点数的运算操作。
如下:
BigDecimal a = new BigDecimal("1.0");
BigDecimal b = new BigDecimal("0.9");
BigDecimal c = new BigDecimal("0.8");
BigDecimal x = a.subtract(b);// 0.1
BigDecimal y = b.subtract(c);// 0.1
System.out.println(x.equals(y));// true
BigDecimal 的大小比较
a.compareTo(b)
: 返回 -1 表示小于,0 表示 等于, 1表示 大于。
BigDecimal a = new BigDecimal("1.0"); BigDecimal b = new BigDecimal("0.9"); System.out.println(a.compareTo(b));// 1
BigDecimal 保留几位小数
通过 setScale
方法设置保留几位小数以及保留规则。保留规则有挺多种,不需要记,IDEA会提示。
BigDecimal m = new BigDecimal("1.255433"); BigDecimal n = m.setScale(3,BigDecimal.ROUND_HALF_DOWN); System.out.println(n);// 1.255
BigDecimal 的使用注意事项:
我们在使用BigDecimal的时候,为了防止精度丢失,推荐使用它的 BigDecimal(String) 构造方法来创建对象。阿里巴巴Java开发手册》对这部分内容也有提到如下图所示。
BigDecimal 主要用来操作(大)浮点数,BigInteger 主要用来操作大整数(超过 long 类型)。
BigDecimal 的实现利用到了 BigInteger, 所不同的是 BigDecimal 加入了小数位的概念
Reference:《阿里巴巴Java开发手册》