用Double加减乘除计算损失精度
程序员文章站
2022-07-15 13:18:14
...
package com.koow.api.util;
import java.math.BigDecimal;
import java.util.regex.Pattern;
public class Money {
/**
* 提供精确加法计算的add方法
* @param value1 被加数
* @param value2 加数
* @return 两个参数的和
*/
public static double add(double value1,double value2){
BigDecimal b1 = new BigDecimal(String.valueOf(value1));
BigDecimal b2 = new BigDecimal(String.valueOf(value2));
return b1.add(b2).doubleValue();
}
/**
* 提供精确减法运算的sub方法
* @param value1 被减数
* @param value2 减数
* @return 两个参数的差
*/
public static double sub(double value1,double value2){
BigDecimal b1 = new BigDecimal(String.valueOf(value1));
BigDecimal b2 = new BigDecimal(String.valueOf(value2));
return b1.subtract(b2).doubleValue();
}
/**
* 提供精确乘法运算的mul方法
* @param value1 被乘数
* @param value2 乘数
* @return 两个参数的积
*/
public static double mul(double value1,double value2){
BigDecimal b1 = new BigDecimal(String.valueOf(value1));
BigDecimal b2 = new BigDecimal(String.valueOf(value2));
return b1.multiply(b2).doubleValue();
}
/**
* 提供精确的除法运算方法div
* @param value1 被除数
* @param value2 除数
* @param scale 精确范围
* @return 两个参数的商
* @throws IllegalAccessException
*/
public static double div(double value1,double value2,int scale) throws IllegalAccessException{
//如果精确范围小于0,抛出异常信息
if(scale<0){
throw new IllegalAccessException("精确度不能小于0");
}
BigDecimal b1 = new BigDecimal(String.valueOf(value1));
BigDecimal b2 = new BigDecimal(String.valueOf(value2));
return b1.divide(b2,scale, BigDecimal.ROUND_HALF_UP).doubleValue();
}
/**
* 手续费计算,手续费不能低于0.01,入参为分,出参为元
* @param value1 分为单位
* @param value2 费率
* @param scale 精确范围
* @return 不小于0.01元的手续费(元为单位)
*/
public static double fee (double value1,double value2,int scale){
BigDecimal b1 = new BigDecimal(String.valueOf(value1));
BigDecimal b2 = new BigDecimal(String.valueOf(value2));
return (b1.multiply(b2).doubleValue())<1?0.01:(b1.multiply(b2).divide(new BigDecimal("100"),scale, BigDecimal.ROUND_HALF_UP).doubleValue());
}
/**
* 判断是否为整数
* @param str 传入的字符串
* @return 是整数返回true
* 否则返回false
*/
public static boolean isInteger(String str) {
Pattern pattern = Pattern.compile("^[-\\+]?[\\d]*$");
return pattern.matcher(str).matches();
}
public static void main(String[] args) throws IllegalAccessException{
System.out.println("用Double计算两数之和(会损失精度):");
System.out.println(Double.valueOf("259115.96")+Double.valueOf("25767.00"));
System.out.println("用Double计算两数之和是否正确:");
System.out.println((Double.valueOf("259115.96")+Double.valueOf("25767.00"))==284882.96);
System.out.println("用BigDecimal计算两数之和是否正确:");
System.out.println(Money.add(Double.valueOf("259115.96"),Double.valueOf("25767.00"))==284882.96);
}
}
上一篇: 浮点数和十六进制数的转换
下一篇: BigDecimal进行加减乘除计算
推荐阅读
-
用php简单实现加减乘除计算器
-
荐 Java BigDecimalの食用方法,老大说我再用Double来进行数值的计算,造成的损失从我工资里扣!˚‧º·(˚ ˃̣̣̥⌓˂̣̣̥ )‧º·˚
-
用Double加减乘除计算损失精度
-
计算机精度问题(Double)
-
用Java实现两个数的加减乘除简易计算器
-
用java写了一个计算器(两个数的加减乘除运算)
-
使用BigDecimal加减乘除运算和数值精度计算(指定小数位数,四舍五入问题)
-
JAVA中如何对double或者float的浮点数进行精度计算长度控制
-
DoubleUtils:double数据计算的工具类,避免精度丢失
-
用php简单实现加减乘除计算器_PHP