• BigDecimal使用以及异常处理


    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)
     建议采用第二种方式,因为第二种方式的结果精度更高
    
  • 相关阅读:
    Object有哪些方法?
    去除掉myeclipse2017页面右上角的图片
    报错 IllegalArgumentException occurred calling getter of cn.itcast.entity.Customer.cid
    如果在applicationContext.xml中没有配置bean的属性,那么也会导致空指针异常
    报错HTTP Status 500
    srm开发(基于ssh)(4)
    报错HTTP Status 500
    HTTP Status 500
    数字
    算法总结——树状数组
  • 原文地址:https://www.cnblogs.com/shiguangmanbu2016/p/5932913.html
Copyright © 2020-2023  润新知