我正在考虑使用BigDecimal来比较两个四舍五入到两位数的货币值。例如,我希望下面的结果是0,因为我比较的是应该舍入为0.02的值与0.02的值。但它会产生-1!有没有正确的方法来做这件事?
这也应该适用于更大的数字,如123.45和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));发布于 2012-06-24 10:13:06
0.02的计算结果为
java.math.BigDecimal = 0.0200000000000000004163336342344337026588618755340576171875你也必须在那里使用setScale(2,RoundingMode.HALF_EVEN)。
发布于 2012-06-24 10:04:27
首先,BigDecimal是不可变的。您必须从setScale方法调用返回结果:
spread = spread.setScale(2, RoundingMode.HALF_EVEN);接下来,您必须提高第二个BigDecimal的准确性,因为它是从double派生的--这不是一个非常精确的实体。所以尝试一个字符串:
spread.compareTo(new BigDecimal("0.02"))https://stackoverflow.com/questions/11174454
复制相似问题