1 /*
2 *
3 在上面简单地介绍了银行家舍入法,目前java支持7中舍入法:
4
5 1、 ROUND_UP:远离零方向舍入。向绝对值最大的方向舍入,只要舍弃位非0即进位。
6
7 2、 ROUND_DOWN:趋向零方向舍入。向绝对值最小的方向输入,所有的位都要舍弃,不存在进位情况。
8
9 3、 ROUND_CEILING:向正无穷方向舍入。向正最大方向靠拢。若是正数,舍入行为类似于ROUND_UP,若为负数,
舍入行为类似于ROUND_DOWN。Math.round()方法就是使用的此模式。
10
11 4、 ROUND_FLOOR:向负无穷方向舍入。向负无穷方向靠拢。若是正数,舍入行为类似于ROUND_DOWN;若为负数,舍入行为类似于ROUND_UP。
12
13 5、 HALF_UP:最近数字舍入(5进)。这是我们最经典的四舍五入。
14
15 6、 HALF_DOWN:最近数字舍入(5舍)。在这里5是要舍弃的。
16
17 7、 HAIL_EVEN:银行家舍入法。
18
19 *
20 */
21
22
23 @Test
24 public void Test3() {
25 System.out.println("12.5的四舍五入值:" + Math.round(12.5));
26 System.out.println("-12.5的四舍五入值:" + Math.round(-12.5));
27 }
28
29 @Test
30 public void Test4() {
31 BigDecimal d = new BigDecimal(100000); // 存款
32 BigDecimal r = new BigDecimal(0.001875 * 3); // 利息
33 BigDecimal i = d.multiply(r).setScale(2, RoundingMode.HALF_EVEN); // 使用银行家算法
34
35 System.out.println("季利息是:" + i);
36 }
37
38 @Test
39 public void Test5() {
40 double f = 111231.5585;
41 BigDecimal b = new BigDecimal(f);
42 double f1 = b.setScale(2, RoundingMode.HALF_UP).doubleValue();
43 System.out.println("f1:" + f1);
44 }
45
46 @Test
47 public void Test6() {
48 java.text.DecimalFormat df = new java.text.DecimalFormat("#.00");
49 String s1 = df.format(3.1415926);
50 String s2 = df.format(3.1465926);
51 System.out.println("s:" + s1);
52 System.out.println("s:" + s2);
53 }
54
55 @Test
56 public void Test7() {
57
58 String s = String.format("%.2f",3.1415926);
59 String s1 = String.format("%.2f",3.1465926);
60 System.out.println("S:"+s);
61 System.out.println("S:"+s1);
62
63 }