在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方法却是四舍五入的)