前言

在实际开发中,遇到例如货币,统计等商业计算的时候,一般需要采用java.math.BigDecimal类来进行精确计算。而这类操作通常都是可预知的,也就是通用的。所以,写了个工具类来方便以后的工作。

这是仓库地址:仓库地址

BigDecimal的构建

一般而言,我们主要从int,long,double,float来进行计算,在构建的时候推荐使用

BigDecimal BigDecimal(String s);

因为通过double构造会损失精度,而String构造是固定的值。

创建以下方法作为通用BigDecimal转化器:

    /**
* Number -> BigDecimal
*/
public static <T extends Number> BigDecimal transform(T v) {
if (v instanceof Double) {
return new BigDecimal(Double.toString((Double) v));
} else if (v instanceof Integer) {
return new BigDecimal(Integer.toString((Integer) v));
} else if (v instanceof Long) {
return new BigDecimal(Long.toString((Long) v));
} else if (v instanceof Short) {
return new BigDecimal(Short.toString((Short) v));
} else if (v instanceof Float) {
return new BigDecimal(Float.toString((Float) v));
} else {
return (BigDecimal) v;
}
}

BigDecimal方法

计算类型加减乘除四种,BigDecimal提供的方法也是围绕这四种计算类型设计的。

BigDecimal add(BigDecimal augend) //加
BigDecimal subtract(BigDecimal subtrahend) //减
BigDecimal multiply(BigDecimal multiplicand) //乘
BigDecimal divide(BigDecimal divisor, int scale, RoundingMode roundingMode) //除

工具类在加减乘除基础上,提供了

  1. 链式计算,类似JDK8 lamada api,爽快丝滑的编程体验
  2. 支持集合求和、求平均
  3. 支持复合计算,例如2*(2+8)

BigDecimal精确计算工具类实用案例

精确转换为BigDecimal,不指定精度

System.out.println(PreciseCalculations.transform(121.11)); //转化double -> 121.11
System.out.println(PreciseCalculations.transform(Integer.MAX_VALUE)); //转化int -> 2147483647
System.out.println(PreciseCalculations.transform(Short.MAX_VALUE)); //转化Short -> 32767
System.out.println(PreciseCalculations.transform(Long.MAX_VALUE)); //转化long -> 9223372036854775807
System.out.println(PreciseCalculations.transform(121.19F)); //转化float -> 121.19

精确转换为BigDecimal,指定精度

System.out.println(PreciseCalculations.transform(121.1111111111, 5)); //精度大于指定精度 -> 121.11111
System.out.println(PreciseCalculations.transform(121.11, 5)); //精度小于指定精度,补零 -> 121.11000

加减乘除

System.out.println(PreciseCalculations.add(12.11, 12.11)); //加法 -> 24.22
System.out.println(PreciseCalculations.subtract(12.11, 12.11)); //减法 -> 0.00
System.out.println(PreciseCalculations.multiply(12.11, 12.11)); //乘法 -> 146.6521
System.out.println(PreciseCalculations.divide(12.11, 2.35, 5)); //除法 -> 5.15319

负数计算

// -1.11 * 13 - 90 = -104.43
System.out.println(new PreciseCalculation(-1.11).multiply(13).add(-90).getValue());
// -11.11111111 + 90 = 78.88888889
System.out.println(PreciseCalculations.add(-11.11111111,90));

集合 求和 求平均值

List<Double> list = Arrays.asList(12.11D, 13.11D, 14.11D, 15.321312D);
System.out.println(PreciseCalculations.sum(list)); //求和 -> Optional[54.651312]
System.out.println(PreciseCalculations.average(list)); //平均值 -> Optional[13.66283]
System.out.println(PreciseCalculations.average(Collections.emptyList())); //空集合 -> Optional.empty

复合计算

// 计算 121.11 * 13 / 60 + 100 - 12 = 114.24050
System.out.println(new PreciseCalculation(121.11).multiply(13).divide(60, 5).add(100).subtract(12).getValue());
//计算 121.11 * 128.59 / (100 + 12) - 100 = 39.04942
System.out.println(new PreciseCalculation(121.11).multiply(128.59).divide(
new PreciseCalculation(100).add(12), 5).subtract(100).getValue());

注意事项

  • PreciseCalculation 核心类,提供加减乘除、集合精确计算方法,内部维护value值,每次计算该value都会改变。
  • PreciseCalculations 基于上述的工具类,方便简单计算时使用。

BigDecimal精确计算工具类的更多相关文章

  1. java精确计算工具类

    java精确计算工具类 import java.math.BigDecimal; import java.math.RoundingMode; import java.math.BigDecimal; ...

  2. java精确计算、精确计算工具类

    java精确计算 package org.aisino.erp.webservice.dzfp.util; import java.math.BigDecimal; public class Math ...

  3. 使用BigDecimal进行精确计算工具类

    package com.develop.util; import java.math.BigDecimal; import java.math.RoundingMode; public class M ...

  4. JAVA简单精确计算工具类

    1 public class ArithUtil { 2 3 // 默认除法运算精度 4 private static final int DEF_DIV_SCALE = 10; 5 6 privat ...

  5. Java-精确计算工具类

    import java.math.BigDecimal; import java.math.RoundingMode; /** * 精确计算工具类(加,减,乘,除,返回较大值,返回较小值) */ pu ...

  6. Java使用BigDecimal精确计算的简单公式计算器

    由于工作需要,写了一个使用BigDecimal运算的精确计算的计算器(然后发现其实比不用BigDecimal的并好不到哪里去) 只能做加减乘除 double类型的数字在千万级别的时候会转成科学计数法, ...

  7. BigDecimal精确计算及陷阱

    BigDecimal通常在涉及到精确计算的时候会用到,下面是自己多次错误使用BigDecimal的总结. 结论: BigDecimal初始化小数时,尽量用字符串形式,例如new BigDecimal( ...

  8. 精度更高的double类型计算工具类(借助BigDecimal类型)

    /** * 提供精確的加法運算 * @param args */ public static double add(double v1, double v2) { BigDecimal b1 = ne ...

  9. 运用BigDecimal精确计算

    package com.wzh.test; import java.math.BigDecimal; public class test { /** * @param args */ public s ...

随机推荐

  1. 19_07_08校内训练[grid]

    题意 现有n*m的长方形网格,每个格子中写着一个数,并构成了[0,n*m)的排列.每次可以将一行循环平移x格,也可以将一列循环平移x格.给出初始状态,给出一个到达给定状态的方案.n*m<=100 ...

  2. C语言入门:一维数组的概要

    数组的概念: 具有相同数据的有序集合 一维数组的定义格式: int a[5]; 类型说明符  数组名(标识符)[常量表达式(长度)]; 一维数组下标 : 数组的下标 从0开始  最大下标值 为 数组的 ...

  3. Python3实现发送邮件和发送短信验证码

    Python3实现发送邮件和发送短信验证码 Python3实现发送邮件: import smtplib from email.mime.text import MIMEText from email. ...

  4. 【WPF学习】第四章 加载和编译XAML

    前面已经介绍过,尽管XAML和WPF这两种技术具有相互补充的作用,但他们也是相互独立的.因此,完全可以创建不使用XAML和WPF应用程序. 总之,可使用三种不同的编码方式来创建WPF应用程序: 只使用 ...

  5. mplayer使用心得[转]

    一直在用mplayer,其他的播放器很少用.以下是我使用过程中的一些心得.  注意,下面用的路径都是在我的电脑上的路径,使用时请不要照抄!应该换成你的电脑上的正确路径.  一.首先还是讲安装方面的问题 ...

  6. 如何用Flink把数据sink到kafka多个(成百上千)topic中

    需求与场景 上游某业务数据量特别大,进入到kafka一个topic中(当然了这个topic的partition数必然多,有人肯定疑问为什么非要把如此庞大的数据写入到1个topic里,历史留下的问题,现 ...

  7. Codeforces_732_D

    http://codeforces.com/problemset/problem/732/D 二分查找. #include<iostream> #include<cstring> ...

  8. Comb结合android开发

    https://blog.csdn.net/qq_29665509/article/details/79272441 参考comb官方文档 https://blog.csdn.net/qq_29665 ...

  9. 小白学 Python 数据分析(4):Pandas (三)数据结构 DataFrame

    在家为国家做贡献太无聊,不如跟我一起学点 Python 人生苦短,我用 Python 前文传送门: 小白学 Python 数据分析(1):数据分析基础 小白学 Python 数据分析(2):Panda ...

  10. ImportError: DLL load failed: 找不到指定的模块;ImportError: numpy.core.multiarray failed to import 报错解决

    python程序运行出错,出错的两行主要信息如下: ImportError: DLL load failed: 找不到指定的模块 ImportError: numpy.core.multiarray ...