Java中BigDecimal工具类(支持空值运算版)

>>最全面的Java面试大纲及答案解析(建议收藏)  

Java中BigDecimal工具类(支持空值运算版)

前言

需要计算的场景绕不过去会使用BigDecimal类,可频繁的判空让代码可读性下降也使代码冗余度增高,不判空又容易报空指针异常,而且有些场景下的计算,结果为空时需要返回null,所以也不可以将将BigDecimal类型的值都初始化为0,会让运算结果产生歧义。为解决上述痛点,于是整理了一个工具类供所有项目一起使用。

一.工具类支持功能

  1. 加减乘除、累加、倍数运算。

  2. Integer、Long、Float、Double、String、Object转为BigDecimal

  3. 除法四舍五入并默认保留20位小数点。

  4. BigDecimal转为String字符串,并禁止用科学计数法显示结果。

  5. 小数点位数保留。

  6. 多种数据类型间混合运算(如Double和Long转为BigDecimal运算)

  7. 以上所有计算,支持所有入参为空时运算

二.工具类源码

复制到类文件DecimalUtils .java中,可直接使用。

import java.math.BigDecimal;

/**
 * @author 大脑补丁
 * @description: BigDecimal运算工具类
 * @create 2020-10-10 14:14
 */

public class DecimalUtils {

 /**
  * 加法计算(result = x + y)
  *
  * @param x 被加数(可为null)
  * @param y 加数 (可为null)
  * @return 和 (可为null)
  * @author 大脑补丁 on 2020-03-30 14:52
  */

 public static BigDecimal add(BigDecimal x, BigDecimal y) {
  if (x == null) {
   return y;
  }
  if (y == null) {
   return x;
  }
  return x.add(y);
 }

 /**
  * 加法计算(result = a + b + c + d)
  *
  * @param a 被加数(可为null)
  * @param b 加数(可为null)
  * @param c 加数(可为null)
  * @param d 加数(可为null)
  * @return BigDecimal (可为null)
  * @author 大脑补丁 on 2020-03-30 22:17
  */

 public static BigDecimal add(BigDecimal a, BigDecimal b, BigDecimal c, BigDecimal d) {
  BigDecimal ab = add(a, b);
  BigDecimal cd = add(c, d);
  return add(ab, cd);
 }

 /**
  * 累加计算(result=x + result)
  *
  * @param x      被加数(可为null)
  * @param result 和 (可为null,若被加数不为为null,result默认值为0)
  * @return result 和 (可为null)
  * @author 大脑补丁 on 2020-03-30 14:16
  */

 public static BigDecimal accumulate(BigDecimal x, BigDecimal result) {
  if (x == null) {
   return result;
  }
  if (result == null) {
   result = new BigDecimal("0");
  }
  return result.add(x);
 }

 /**
  * 减法计算(result = x - y)
  *
  * @param x 被减数(可为null)
  * @param y 减数(可为null)
  * @return BigDecimal 差 (可为null)
  * @author 大脑补丁 on 2020-03-30 14:47
  */

 public static BigDecimal subtract(BigDecimal x, BigDecimal y) {
  if (x == null || y == null) {
   return null;
  }
  return x.subtract(y);
 }

 /**
  * 乘法计算(result = x × y)
  *
  * @param x 乘数(可为null)
  * @param y 乘数(可为null)
  * @return BigDecimal 积
  * @author 大脑补丁 on 2020-03-30 14:14
  */

 public static BigDecimal multiply(BigDecimal x, BigDecimal y) {
  if (x == null || y == null) {
   return null;
  }
  return x.multiply(y);
 }

 /**
  * 除法计算(result = x ÷ y)
  *
  * @param x 被除数(可为null)
  * @param y 除数(可为null)
  * @return 商 (可为null,四舍五入,默认保留20位小数)
  * @author 大脑补丁 on 2020-03-30 14:15
  */

 public static BigDecimal divide(BigDecimal x, BigDecimal y) {
  if (x == null || y == null || y.compareTo(BigDecimal.ZERO) == 0) {
   return null;
  }
  // 结果为0.000..时,不用科学计数法展示
  return stripTrailingZeros(x.divide(y, 20, BigDecimal.ROUND_HALF_UP));
 }

 /**
  * 转为字符串(防止返回可续计数法表达式)
  *
  * @param x 要转字符串的小数
  * @return String
  * @author 大脑补丁 on 2020-03-30 15:08
  */

 public static String toPlainString(BigDecimal x) {
  if (x == null) {
   return null;
  }
  return x.toPlainString();
 }

 /**
  * 保留小数位数
  *
  * @param x     目标小数
  * @param scale 要保留小数位数
  * @return BigDecimal 结果四舍五入
  * @author 大脑补丁 on 2020-03-30 15:17
  */

 public static BigDecimal scale(BigDecimal x, int scale) {
  if (x == null) {
   return null;
  }
  return x.setScale(scale, BigDecimal.ROUND_HALF_UP);
 }

 /**
  * 整型转为BigDecimal
  *
  * @param x(可为null)
  * @return BigDecimal (可为null)
  * @author 大脑补丁 on 2020-03-30 22:24
  */

 public static BigDecimal toBigDecimal(Integer x) {
  if (x == null) {
   return null;
  }
  return new BigDecimal(x.toString());
 }

 /**
  * 长整型转为BigDecimal
  *
  * @param x(可为null)
  * @return BigDecimal (可为null)
  * @author 大脑补丁 on 2020-03-30 22:24
  */

 public static BigDecimal toBigDecimal(Long x) {
  if (x == null) {
   return null;
  }
  return new BigDecimal(x.toString());
 }

 /**
  * 双精度型转为BigDecimal
  *
  * @param x(可为null)
  * @return BigDecimal (可为null)
  * @author 大脑补丁 on 2020-03-30 22:24
  */

 public static BigDecimal toBigDecimal(Double x) {
  if (x == null) {
   return null;
  }
  return new BigDecimal(x.toString());
 }

 /**
  * 单精度型转为BigDecimal
  *
  * @param x(可为null)
  * @return BigDecimal (可为null)
  * @author 大脑补丁 on 2020-03-30 22:24
  */

 public static BigDecimal toBigDecimal(Float x) {
  if (x == null) {
   return null;
  }
  return new BigDecimal(x.toString());
 }

 /**
  * 字符串型转为BigDecimal
  *
  * @param x(可为null)
  * @return BigDecimal (可为null)
  * @author 大脑补丁 on 2020-03-30 22:24
  */

 public static BigDecimal toBigDecimal(String x) {
  if (x == null) {
   return null;
  }
  return new BigDecimal(x);
 }

 /**
  * 对象类型转为BigDecimal
  *
  * @param x(可为null)
  * @return BigDecimal (可为null)
  * @author 大脑补丁 on 2020-03-30 22:24
  */

 public static BigDecimal toBigDecimal(Object x) {
  if (x == null) {
   return null;
  }
  BigDecimal result = null;
  try {
   result = new BigDecimal(x.toString());
  } catch (Exception e) {
   e.printStackTrace();
  }
  return result;
 }

 /**
  * 倍数计算,用于单位换算
  *
  * @param x        目标数(可为null)
  * @param multiple 倍数 (可为null)
  * @return BigDecimal (可为null)
  * @author 大脑补丁 on 2020-03-30 22:43
  */

 public static BigDecimal multiple(BigDecimal x, Integer multiple) {
  if (x == null || multiple == null) {
   return null;
  }
  return DecimalUtils.multiply(x, toBigDecimal(multiple));
 }

 /**
  * 去除小数点后的0(如: 输入1.000返回1)
  *
  * @param x 目标数(可为null)
  * @return
  */

 public static BigDecimal stripTrailingZeros(BigDecimal x) {
  if (x == null) {
   return null;
  }
  return x.stripTrailingZeros();
 }
}

三.如何使用

使用BigDecimal计算的时候,再也不用考虑判空、初始化数值了。代码简洁清爽了许多。

public static void main(String[] args) {
  // 定义两个变量,进行运算
  BigDecimal a = new BigDecimal("100");
  BigDecimal b = new BigDecimal("3.14");

  // 加 a+b
  BigDecimal c1 = DecimalUtils.add(a, b);
  // 减 a-b
  BigDecimal c2 = DecimalUtils.subtract(a, b);
  // 乘 a*b
  BigDecimal c3 = DecimalUtils.multiply(a, b);
  // 除 a/b
  BigDecimal c4 = DecimalUtils.subtract(a, b);

  // 累加 sum = a + sum
  BigDecimal sum = null;
  sum = DecimalUtils.accumulate(a, sum);

  // 将变量a结果保留2位小数
  BigDecimal c5 = DecimalUtils.scale(a, 2);

  // 变量a的1000倍运算   a*1000
  BigDecimal c6 = DecimalUtils.multiple(a, 1000);

  //Integer、Long、Float、Double、String、Object转为BigDecimal。
  Object obj = 123;
  BigDecimal c7 = DecimalUtils.toBigDecimal(obj);

  // BigDecimal转为字符串
  String str = DecimalUtils.toPlainString(a);

  // 不同数据类型之间混合运算(如:Double类型除以Long类型)
  BigDecimal mixCalc = DecimalUtils.divide(DecimalUtils.toBigDecimal(1.23D),DecimalUtils.toBigDecimal(1234567L));


 }

总结

BigDecimal是Java常用的计算工具,使用本工具类简化了你重复代码的编写,只需要关注业务逻辑即可,不必担心空指针的处理了。

来源:blog.csdn.net/x541211190/article/details/109013913

精彩推荐

强大,10k+点赞的 SpringBoot 后台管理系统竟然出了详细教程!
冒着被开除的风险也要给大家看看看这份SpringCloud 总结
微服务 2.0 技术栈选型手册
天天在用Stream,那你知道如此强大的Stream的实现原理吗?

Java中BigDecimal工具类(支持空值运算版)

原文始发于微信公众号(Java笔记虾):Java中BigDecimal工具类(支持空值运算版)