实例一、保留小数点后两位,四舍五入

//使用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());

 

 posted on 2020-03-17 17:36  布鲁布鲁sky  阅读(2647)  评论(0编辑  收藏  举报