转自:https://www.cnblogs.com/mr-wuxiansheng/p/6959587.html
/*
*
在上面简单地介绍了银行家舍入法,目前java支持7中舍入法:
1、 ROUND_UP:远离零方向舍入。向绝对值最大的方向舍入,只要舍弃位非0即进位。
2、 ROUND_DOWN:趋向零方向舍入。向绝对值最小的方向输入,所有的位都要舍弃,不存在进位情况。
3、 ROUND_CEILING:向正无穷方向舍入。向正最大方向靠拢。若是正数,舍入行为类似于ROUND_UP,若为负数,
舍入行为类似于ROUND_DOWN。Math.round()方法就是使用的此模式。
4、 ROUND_FLOOR:向负无穷方向舍入。向负无穷方向靠拢。若是正数,舍入行为类似于ROUND_DOWN;若为负数,舍入行为类似于ROUND_UP。
5、 HALF_UP:最近数字舍入(5进)。这是我们最经典的四舍五入。
6、 HALF_DOWN:最近数字舍入(5舍)。在这里5是要舍弃的。
7、 HAIL_EVEN:银行家舍入法。
*
*/
@Test
public void Test3() {
System.out.println("12.5的四舍五入值:" + Math.round(12.5));
System.out.println("-12.5的四舍五入值:" + Math.round(-12.5));
}
@Test
public void Test4() {
BigDecimal d = new BigDecimal(100000); // 存款
BigDecimal r = new BigDecimal(0.001875 * 3); // 利息
BigDecimal i = d.multiply(r).setScale(2, RoundingMode.HALF_EVEN); // 使用银行家算法
System.out.println("季利息是:" + i);
}
@Test
public void Test5() {
double f = 111231.5585;
BigDecimal b = new BigDecimal(f);
double f1 = b.setScale(2, RoundingMode.HALF_UP).doubleValue();
System.out.println("f1:" + f1);
}
@Test
public void Test6() {
java.text.DecimalFormat df = new java.text.DecimalFormat("#.00");
String s1 = df.format(3.1415926);
String s2 = df.format(3.1465926);
System.out.println("s:" + s1);
System.out.println("s:" + s2);
}
@Test
public void Test7() {
String s = String.format("%.2f",3.1415926);
String s1 = String.format("%.2f",3.1465926);
System.out.println("S:"+s);
System.out.println("S:"+s1);
}
补充:
如果需要进一还可以使用: