我正在考虑使用BigDecimal来比较两个四舍五入到两位数的货币值。例如,我希望以下产生0,因为我正在比较应该舍入到0.02的东西和0.02。但它产生-1 !!有没有正确的方法来做到这一点?
这也适用于较大的数字,如123.45 vs 123.4534 ...当使用“compareTo”时应该产生0。
我尝试过使用数学语境,但它看起来并不优雅......有正确的方法吗?
BigDecimal spread = new BigDecimal(0.01934);
spread.setScale(2, RoundingMode.HALF_EVEN);
System.out.format("0.0193 ? 0.02 = %d\n", spread.compareTo(new BigDecimal(0.02)));
和解决方案是:
BigDecimal spread = new BigDecimal(0.01934).setScale(2, RoundingMode.HALF_EVEN);
BigDecimal loSpread = new BigDecimal(0.02).setScale(2, RoundingMode.HALF_EVEN);
System.out.format("0.0193 ? 0.02 = %d\n", spread.compareTo(loSpread));
答案 0 :(得分:10)
首先,BigDecimal是不可变的。您必须从setScale方法调用返回结果:
spread = spread.setScale(2, RoundingMode.HALF_EVEN);
接下来,您必须提高第二个BigDecimal的准确性,因为它是从双精度实体派生而来的。所以尝试一下String:
spread.compareTo(new BigDecimal("0.02"))
答案 1 :(得分:5)
0.02被评估为
java.math.BigDecimal = 0.0200000000000000004163336342344337026588618755340576171875
你也必须设置SetScale(2,RoundingMode.HALF_EVEN)。