您遇到的问题是double不能精确表示,并且您基于此不精确的数字而四舍五入。
BigDecimal bd = new BigDecimal(1.555d);System.out.println("bd=" + bd);bd = bd.setScale(2, RoundingMode.HALF_UP);System.out.println("after rounding bd=" + bd);double d = bd.doublevalue();System.out.println("after rounding d=" + d);
bd=1.5549999999999999378275106209912337362766265869140625after rounding bd=1.55after rounding d=1.55
然而
BigDecimal bd = BigDecimal.valueOf(1.555d);System.out.println("bd=" + bd);bd = bd.setScale(2, RoundingMode.HALF_UP);System.out.println("after rounding bd=" + bd);double d = bd.doublevalue();System.out.println("after rounding d=" + d);
版画
bd=1.555after rounding bd=1.56after rounding d=1.56
之所以起作用,是因为BigDecimal.valueOf根据打印时出现的倍数进行一些额外的舍入。
但是除非性能/简单性不是问题,否则我不会使用BigDecimal。
double d = 1.555d;System.out.println("d=" + d);d = roundToTwoPlaces(d);System.out.println("after rounding d=" + d);public static double roundToTwoPlaces(double d) { return ((long) (d < 0 ? d * 100 - 0.5 : d * 100 + 0.5)) / 100.0;}
版画
d=1.555after rounding d=1.56
有关更多详细信息,请再次将您的钱加倍,以比较不同取整方式的效果。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)