我正在考虑使用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)));
Run Code Online (Sandbox Code Playgroud)
解决方案是:
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));
Run Code Online (Sandbox Code Playgroud)
Hov*_*els 10
首先,BigDecimal是不可变的.您必须从setScale方法调用返回结果:
spread = spread.setScale(2, RoundingMode.HALF_EVEN);
Run Code Online (Sandbox Code Playgroud)
接下来,您必须提高第二个BigDecimal的准确性,因为它是从双精度实体派生而来的.所以尝试一个字符串:
spread.compareTo(new BigDecimal("0.02"))
Run Code Online (Sandbox Code Playgroud)
0.02被评估为
java.math.BigDecimal = 0.0200000000000000004163336342344337026588618755340576171875
Run Code Online (Sandbox Code Playgroud)
你也必须在那里设置SetScale(2,RoundingMode.HALF_EVEN).