如果基本的整数和浮点数精度不能满足需求,就可以使用java.math包中的两个很有用的类: BigInteger和BigDecimal。这两个类可以处理任意长度的数值。BigInteger类实现了任意精度的整数运算,BigDecimal实现了任意精度的浮点数运算。大数值
2024年04月09日
如果基本的整数和浮点数精度不能满足需求,就可以使用java.math包中的两个很有用的类: BigInteger和BigDecimal。这两个类可以处理任意长度的数值。BigInteger类实现了任意精度的整数运算,BigDecimal实现了任意精度的浮点数运算。大数值
2024年04月09日
/**
* @Title:
* @Description: 数学计算
*/
public class BigDecimalUtil {
/**
* 功能描述: <br>
* 精确度
*/
private static final int DEF_DIV_SCALE = 5;
/**
* 提供精确的加法运算。
* @param v1 加数
* @param v2 被加数
* @return 两个参数的和
*/
public static BigDecimal sum(String v1, String v2) {
BigDecimal b1 = new BigDecimal(v1);
BigDecimal b2 = new BigDecimal(v2);
return strToBigDecimal(b2.add(b1).toString());
}
/**
* 提供精确的减法运算。
* @param v1 减数
* @param v2 被减数
* @return 两个参数的差
*/
public static BigDecimal subString(String v1, String v2) {
BigDecimal b1 = new BigDecimal(v1);
BigDecimal b2 = new BigDecimal(v2);
return strToBigDecimal(b1.subtract(b2).toString());
}
/**
* 提供精确的乘法运算。
* @param v1 乘数
* @param v2 被乘数
* @return 两个参数的积
*/
public static BigDecimal mul(String v1, String v2) {
BigDecimal b1 = new BigDecimal(v1);
BigDecimal b2 = new BigDecimal(v2);
return BigDecimal.valueOf(b2.multiply(b1).doubleValue());
}
/**
* 提供(相对)精确的除法运算,当发生除不尽的情况时,精确到
* 小数点以后10位,以后的数字四舍五入。
* @param v1 除数
* @param v2 被除数
* @return 两个参数的商
*/
public static BigDecimal div(double v1, double v2) {
return BigDecimal.valueOf(div(v2, v1, DEF_DIV_SCALE).doubleValue());
}
/**
* 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指
* 定精度,以后的数字四舍五入。
* @param v1 除数
* @param v2 被除数
* @param scale 表示表示需要精确到小数点以后几位。
* @return 两个参数的商
*/
public static BigDecimal div(double v1, double v2, int scale) {
if (scale < 0) {
throw new IllegalArgumentException(
"The scale must be a positive integer or zero");
}
BigDecimal b1 = BigDecimal.valueOf(v1);
BigDecimal b2 = BigDecimal.valueOf(v2);
return BigDecimal.valueOf(b1.divide(b2, scale, BigDecimal.ROUND_HALF_UP).doubleValue());
}
/**
* 提供精确的小数位四舍五入处理。
* @param v 需要四舍五入的数字
* @param scale 小数点后保留几位
* @return 四舍五入后的结果
*/
public static BigDecimal round(double v, int scale) {
if (scale < 0) {
throw new IllegalArgumentException("The scale must be a positive integer or zero");
}
BigDecimal b = BigDecimal.valueOf(v);
BigDecimal one = new BigDecimal("1");
return BigDecimal.valueOf(b.divide(one, scale, BigDecimal.ROUND_HALF_UP).doubleValue());
}
public static BigDecimal strToBigDecimal(String string) {
BigDecimal b = new BigDecimal(string);
return b;
}
2024年04月09日
1. 引言 在Java中,BigInteger类和BigDecimal类是用于处理大整数和大浮点数的类,它们提供了对任意精度的整数和浮点数的运算和处理能力。本教程将介绍这两个类的基本用法和常见操作。
2024年04月09日
《阿里巴巴Java开发手册》中提到:浮点数之间的等值判断,基本数据类型不能用==来比较,包装数据类型不能用 equals 来判断(总之尽量少用浮点数,多使用bigDecimal)。 具体原理和浮点数的编码方式有关,这里就不多提了,我们下面直接上实例:1.BigDecimal 的用处
2024年04月09日
加法:add 减法:subtract 乘法:multiply 除法:divide BigDecimal bd1 = new BigDecimal("15"); BigDecimal bd2 = new BigDecimal("20"); BigDecimal bd3;