Java工具類之——BigDecimal運算封裝(包含金額的計算方式)

執筆記憶的空白發表於2017-03-23

日常對於金額計算,應該都是用的BigDecimal,  可是苦於沒有好的工具類方法,現在貢獻一個我正在用的對於數字計算的工具類,專案中就是用的這個,簡單粗暴好用,話不多說,程式碼奉上(該工具類需要引入google的一個jar  ,com.google.common.base.Optional,具體maven引入看文章末尾):


import java.math.BigDecimal;

public class NumberArithmeticUtils {
	
	
	/**
	 * BigDecimal的加法運算封裝
	 * @author : shijing
	 * 2017年3月23日下午4:53:21
	 * @param b1
	 * @param bn
	 * @return
	 */
   public static BigDecimal safeAdd(BigDecimal b1, BigDecimal... bn) {
       if (null == b1) {
           b1 = BigDecimal.ZERO;
       }
       if (null != bn) {
           for (BigDecimal b : bn) {
               b1 = b1.add(null == b ? BigDecimal.ZERO : b);
           }
       }
       return b1;
   }

   /**
    * Integer加法運算的封裝
    * @author : shijing
    * 2017年3月23日下午4:54:08
    * @param b1   第一個數
    * @param bn   需要加的加法陣列
    * @注 : Optional  是屬於com.google.common.base.Optional<T> 下面的class
    * @return
    */
   public static Integer safeAdd(Integer b1, Integer... bn) {
       if (null == b1) {
           b1 = 0;
       }
       Integer r = b1;
       if (null != bn) {
           for (Integer b : bn) {
               r += Optional.fromNullable(b).or(0);
           }
       }
       return r > 0 ? r : 0;
   }

   /**
    * 計算金額方法
    * @author : shijing
    * 2017年3月23日下午4:53:00
    * @param b1
    * @param bn
    * @return
    */
   public static BigDecimal safeSubtract(BigDecimal b1, BigDecimal... bn) {
       return safeSubtract(true, b1, bn);
   }

   /**
    * BigDecimal的安全減法運算
    * @author : shijing
    * 2017年3月23日下午4:50:45
    * @param isZero  減法結果為負數時是否返回0,true是返回0(金額計算時使用),false是返回負數結果
    * @param b1		   被減數
    * @param bn        需要減的減數陣列
    * @return
    */
   public static BigDecimal safeSubtract(Boolean isZero, BigDecimal b1, BigDecimal... bn) {
       if (null == b1) {
           b1 = BigDecimal.ZERO;
       }
       BigDecimal r = b1;
       if (null != bn) {
           for (BigDecimal b : bn) {
               r = r.subtract((null == b ? BigDecimal.ZERO : b));
           }
       }
       return isZero ? (r.compareTo(BigDecimal.ZERO) == -1 ? BigDecimal.ZERO : r) : r;
   }

   /**
    * 整型的減法運算,小於0時返回0
    * @author : shijing
    * 2017年3月23日下午4:58:16
    * @param b1
    * @param bn
    * @return
    */
   public static Integer safeSubtract(Integer b1, Integer... bn) {
       if (null == b1) {
           b1 = 0;
       }
       Integer r = b1;
       if (null != bn) {
           for (Integer b : bn) {
               r -= Optional.fromNullable(b).or(0);
           }
       }
       return null != r && r > 0 ? r : 0;
   }

   /**
    * 金額除法計算,返回2位小數(具體的返回多少位大家自己看著改吧)
    * @author : shijing
    * 2017年3月23日下午5:02:17
    * @param b1
    * @param b2
    * @return
    */
   public static <T extends Number> BigDecimal safeDivide(T b1, T b2){
       return safeDivide(b1, b2, BigDecimal.ZERO);
   }

   /**
    * BigDecimal的除法運算封裝,如果除數或者被除數為0,返回預設值
    * 預設返回小數位後2位,用於金額計算
    * @author : shijing
    * 2017年3月23日下午4:59:29
    * @param b1
    * @param b2
    * @param defaultValue
    * @return
    */
   public static <T extends Number> BigDecimal safeDivide(T b1, T b2, BigDecimal defaultValue) {
       if (null == b1 || null == b2) {
           return defaultValue;
       }
       try {
           return BigDecimal.valueOf(b1.doubleValue()).divide(BigDecimal.valueOf(b2.doubleValue()), 2, BigDecimal.ROUND_HALF_UP);
       } catch (Exception e) {
           return defaultValue;
       }
   }

   /**
    * BigDecimal的乘法運算封裝
    * @author : shijing
    * 2017年3月23日下午5:01:57
    * @param b1
    * @param b2
    * @return
    */
   public static <T extends Number> BigDecimal safeMultiply(T b1, T b2) {
       if (null == b1 || null == b2) {
           return BigDecimal.ZERO;
       }
       return BigDecimal.valueOf(b1.doubleValue()).multiply(BigDecimal.valueOf(b2.doubleValue())).setScale(2, BigDecimal.ROUND_HALF_UP);
   }

}

Optional所在的jar以及版本:guava-18.0.ar

pom.xml配置:

<!-- https://mvnrepository.com/artifact/com.google.guava/guava -->
<dependency>
    <groupId>com.google.guava</groupId>
    <artifactId>guava</artifactId>
    <version>18.0</version>
</dependency>




相關文章