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 }