BigDecimal使用以及异常处理

来源:互联网 发布:淘宝流量钱包流量充值 编辑:程序博客网 时间:2024/05/17 21:55
  1. 对商品的价格进行格式化,比如所有商品的价格保留两位小数
/**  *   * @param bd  商品的价格  * @param num 保留几位小数,如num = 2  * @return  */  public static String formatPrice(BigDecimal bd,int num){      if(bd == null || num < 0){          return null;      }      bd = bd.setScale(num, BigDecimal.ROUND_HALF_UP);      return bd + "";  }  
   其中BigDecimal.ROUND_HALF_UP表示采用"四舍五入"的模式处理价格
  1. 将商品的价格由元转为分,便于前端分隔展现
/**  * 元转换为分  * @param bd 商品的价格  * @return  */  public static String yuanToCent(BigDecimal bd){      if(bd == null){          return null;      }      bd = bd.multiply(new BigDecimal(100)).setScale(0, BigDecimal.ROUND_HALF_EVEN);      return bd + "";  }  
   其中setScale(0, BigDecimal.ROUND_HALF_EVEN)表示采用"四舍五入"的模式处理价格,并且结果不保留小数.

异常处理:
用BigDecimal进行除法计算时抛出java.lang.ArithmeticException: Non-terminating decimal expansion; no exact representable decimal result异常.
比如用new BigDecimal(30).divide(new BigDecimal(7))就会抛这个异常,异常原因:BigDecimal的divide方法进行除法时当不整除,出现无限循环小数时,就会抛这个异常.

解决办法:
给divide设置精确的小数点位数或”舍入”模式,如

`new BigDecimal(30).divide(new  BigDecimal(7), BigDecimal.ROUND_HALF_UP).setScale(2,BigDecimal.ROUND_HALF_UP)`
 new BigDecimal(30).divide(new BigDecimal(7), 2, BigDecimal.ROUND_HALF_UP)
 建议采用第二种方式,因为第二种方式的结果精度更高
0 0