實例一、保留小數點后兩位,四舍五入
//使用BigDecimal,更精准的計算,避免小數點后出現精准度丟失現象。比如:25.230000000001 //初始化值是Stirng類型,如果是Double,也轉為String:Double.toString(double)方法 //小數點保留兩位
BigDecimal num1 = new BigDecimal("0.00"); BigDecimal num2 = new BigDecimal("0.00"); BigDecimal bd1 = new BigDecimal("256"); BigDecimal bd2 = new BigDecimal(Double.toString(0.22)); //加減乘除操作,精度取小數點后兩位
num1 = bd1.multiply(bd2).setScale(2, BigDecimal.ROUND_HALF_UP);
num2 = bd1.subtract(num1).setScale(2, BigDecimal.ROUND_HALF_UP);
BigDecimal 處理小數
setScale(1) 表示保留一位小數,默認用四舍五入方式 setScale(1,BigDecimal.ROUND_DOWN)直接刪除多余的小數位,如2.35會變成2.3 setScale(1,BigDecimal.ROUND_UP)進位處理,2.35變成2.4 setScale(1,BigDecimal.ROUND_HALF_UP)四舍五入(5則向上入),2.35變成2.4 setScaler(1,BigDecimal.ROUND_HALF_DOWN)四舍五入(5則向下舍),2.35變成2.3
實例二、展示結果為百分比格式,百分比后面兩位小數
DecimalFormat df = new DecimalFormat("0.00%"); //入參為double數字
BigDecimal bd = new BigDecimal(150 / 120); //因為是百分比,這里數字是4
String billRate = df.format(bd.setScale(4, BigDecimal.ROUND_HALF_UP).doubleValue());