博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
BigDecimal的加减乘除
阅读量:7006 次
发布时间:2019-06-27

本文共 2553 字,大约阅读时间需要 8 分钟。

hot3.png

import java.math.BigDecimal;public class PreciseCompute { // 默认除法运算精度 private static final int DEF_DIV_SCALE = 3; /**  * 提供精确的加法运算。  *   * @param v1  *            被加数  * @param v2  *            加数  * @return 两个参数的和  */ public static double add(double v1, double v2) {  BigDecimal b1 = new BigDecimal(Double.toString(v1));  BigDecimal b2 = new BigDecimal(Double.toString(v2));  return b1.add(b2).doubleValue(); } /**  * 提供精确的减法运算。  *   * @param v1  *            被减数  * @param v2  *            减数  * @return 两个参数的差  */ public static double sub(double v1, double v2) {  BigDecimal b1 = new BigDecimal(Double.toString(v1));  BigDecimal b2 = new BigDecimal(Double.toString(v2));  return b1.subtract(b2).doubleValue(); } /**  * 提供精确的乘法运算。  *   * @param v1  *            被乘数  * @param v2  *            乘数  * @return 两个参数的积  */ public static double mul(double v1, double v2) {  BigDecimal b1 = new BigDecimal(Double.toString(v1));  BigDecimal b2 = new BigDecimal(Double.toString(v2));  return b1.multiply(b2).doubleValue(); } /**  * 提供(相对)精确的除法运算,当发生除不尽的情况时,精确到 小数点以后3位,以后的数字四舍五入。  *   * @param v1  *            被除数  * @param v2  *            除数  * @return 两个参数的商  */ public static double div(double v1, double v2) {  return div(v1, v2, DEF_DIV_SCALE); } /**  * 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指 定精度,以后的数字四舍五入。  *   * @param v1  *            被除数  * @param v2  *            除数  * @param scale  *            表示表示需要精确到小数点以后几位。  * @return 两个参数的商  */ public static double div(double v1, double v2, int scale) {  if (scale < 0) {   throw new IllegalArgumentException("The scale must be a positive integer or zero");  }  BigDecimal b1 = new BigDecimal(Double.toString(v1));  BigDecimal b2 = new BigDecimal(Double.toString(v2));  return b1.divide(b2, scale, BigDecimal.ROUND_HALF_UP).doubleValue(); } /**  * 提供精确的小数位四舍五入处理。  *   * @param v  *            需要四舍五入的数字  * @param scale  *            小数点后保留几位  * @return 四舍五入后的结果  */ public static double round(double v, int scale) {  if (scale < 0) {   throw new IllegalArgumentException("The scale must be a positive integer or zero");  }  BigDecimal b = new BigDecimal(Double.toString(v));  BigDecimal ne = new BigDecimal("1");  return b.divide(ne, scale, BigDecimal.ROUND_HALF_UP).doubleValue(); }   public static void main(String[] args)throws Exception{  System.out.println(PreciseCompute.round(new Double(0.33333), 2));  System.out.println(PreciseCompute.div(new Double(7.5), new Double(7)));  System.out.println(PreciseCompute.mul(new Double(7.5), new Double(0.7))); }}

转载于:https://my.oschina.net/u/572362/blog/634110

你可能感兴趣的文章
EALayout 实践
查看>>
Software development --daily scrum team
查看>>
B1036. 跟奥巴马一起编程(15)
查看>>
软件项目后期收官时的一些问题和想法
查看>>
机器学习:线性回归
查看>>
PHP连接PostgreSQL连接问题
查看>>
WebService案例入门(基础篇)
查看>>
回档|NOIP2012 同余方程
查看>>
久违的博客园
查看>>
Alpha冲刺(9/10)
查看>>
【转】B树的插入和删除
查看>>
一个小案例明白onLayout()、onMeasure()方法的作用
查看>>
陶哲轩实分析定理 11.4.3 $\max$与$\min$保持黎曼可积性
查看>>
SIP、Mobicents扫盲
查看>>
rest-framework-版本控制
查看>>
android wifi obtainmessage sendmessage解析
查看>>
C#实现时间戳timestamp与时间相互转换
查看>>
定义变量
查看>>
合并顺序表
查看>>
APP性能优化系列(二):Android渲染机制
查看>>