1.整数型运算时,结果会自动去除小数点后面的部分,如果需要适当的保留几位小数,需要转为fload类型,分子或者分母或者都转
如:
计算5除以6,保留2位小数 BigDecimal b = new BigDecimal((float)5/6);四舍五入保留2位 Double result = b.setScale(2,BigDecimal.ROUND_HALF_UP).doubleValue();如需保留3位 Double result = b.setScale(3,BigDecimal.ROUND_HALF_UP).doubleValue();
2.第二种方法
DecimalFormat df = new DecimalFormat("0.00"); Double result = df.format((float)5/6);如需保留3位 DecimalFormat df = new DecimalFormat("0.000"); Double result = df.format((float)5/6);
3.第三种
String percent = new BigDecimal((double)num*100/sum).setScale(2,BigDecimal.ROUND_HALF_UP)+"%";
4.第四种:
计算百分比
/** * a / b 计算百分比 * @param a * @param b * @return eg:65.32% */ public static String ADivideBPercent(BigDecimal a,BigDecimal b){ String percent = b == null ? "-" : b.compareTo(new BigDecimal(0)) == 0 ? "-": a == null ? "0.00%" : a.multiply(new BigDecimal(100)).divide(b,2,BigDecimal.ROUND_HALF_UP) + "%"; return percent; }
评论 (0)