在Java中使用一些方法进行四舍五入会出现和预期不同的结果,这是因为这些方法使用的原则实际为:四舍六入五考虑,五后非零就进一,五后皆零看奇偶,五前为偶应舍去,五前为奇要进一。

        1.四舍六入五考虑时出现五的情况

double f=9.545d;
System.out.println(new BigDecimal(f).setScale(2,BigDecimal.ROUND_HALF_UP).doubleValue());
System.out.println(new java.text.DecimalFormat("#.00").format(f));
System.out.println();
f=9.555d;
System.out.println(new BigDecimal(f).setScale(2,BigDecimal.ROUND_HALF_UP).doubleValue());
System.out.println(new java.text.DecimalFormat("#.00").format(f));
System.out.println();
f=9.5551d;
System.out.println(new BigDecimal(f).setScale(2,BigDecimal.ROUND_HALF_UP).doubleValue());
System.out.println(new java.text.DecimalFormat("#.00").format(f));

运行结果:
9.54
9.54

9.55
9.55

9.56
9.56

        2.四舍五入时出现五的情况

double f=9.545d;
System.out.println(String.format("%.2f", f));
System.out.println(Math.round(f*100)*0.01);
System.out.println();
f=9.555d;
System.out.println(String.format("%.2f", f));
System.out.println(Math.round(f*100)*0.01);
System.out.println();
f=9.5551d;
System.out.println(String.format("%.2f", f));
System.out.println(Math.round(f*100)*0.01);

运行结果:
9.55
9.55

9.56
9.56

9.56
9.56

        所以,从上边运行的情况来看,如果需要严格遵守四舍五入,需要使用第二种情况才可以。(ps:这里顺便提一下,js中使用toFixed其实是四舍六如五考虑的情况,如果希望严格的四舍五入,可以使用(Math.round(a*100)/100).toFixed(2)。但是mysql的ROUND方法却是四舍五入的)