我们来看一看java中BigDecimal的用法
public class MathUtil {
// 加法
public static Double add(double a,double b,int scal) throws Exception{
BigDecimal add1 = conversionToBigDecimal(a);
BigDecimal add2 = conversionToBigDecimal(b);
Double result = add1.add(add2).setScale(scal,BigDecimal.ROUND_HALF_UP).doubleValue();
return result;
}
// 减法
public static Double subtract(double a,double b,int scal) throws Exception{
BigDecimal subtract1 = conversionToBigDecimal(a);
BigDecimal subtract2 = conversionToBigDecimal(b);
Double result = subtract1.subtract(subtract2).setScale(scal,BigDecimal.ROUND_HALF_UP).doubleValue();
return result;
}
// 乘法
public static Double multiply(double a,double b,int scal) throws Exception{
BigDecimal multiply1 = conversionToBigDecimal(a);
BigDecimal multiply2 = conversionToBigDecimal(b);
Double result = multiply1.multiply(multiply2).setScale(scal,BigDecimal.ROUND_HALF_UP).doubleValue();
return result;
}
// 除法
public static Double divide(double a,double b,int scal) throws Exception{
BigDecimal divide1 = conversionToBigDecimal(a);
BigDecimal divide2 = conversionToBigDecimal(b);
Double result = divide1.divide(divide2,scal,BigDecimal.ROUND_HALF_UP).doubleValue();
return result;
}
// 类型转换
public static BigDecimal conversionToBigDecimal(Object obj) throws Exception
{
if (obj instanceof Double)
{
return new BigDecimal(obj.toString());
}
else if (obj instanceof Float)
{
return new BigDecimal(obj.toString());
}
else if (obj instanceof Integer)
{
return new BigDecimal(obj.toString());
}
else if (obj instanceof Long)
{
return new BigDecimal(obj.toString());
}
else if (obj instanceof Byte)
{
return new BigDecimal(obj.toString());
}
else if (obj instanceof Short)
{
return new BigDecimal(obj.toString());
}
else
{
throw new Exception("不能转换");
}
}
下面我们来看看BigDecimal的setScale方法
BigDecimal.setScale()方法用于格式化小数点
表示保留一位小数,默认用四舍五入方式
setScale(1)
直接删除多余的小数位,如2.35会变成2.3
setScale(1,BigDecimal.ROUND_DOWN)
进位处理,2.35变成2.4
setScale(1,BigDecimal.ROUND_UP)
四舍五入,2.35变成2.4
setScale(1,BigDecimal.ROUND_HALF_UP)
四舍五入,2.35变成2.3,如果是5则向下舍
setScaler(1,BigDecimal.ROUND_HALF_DOWN)
注意点一
scale指的是你小数点后的位数。scale()就是BigDecimal类中的方法。如
BigDecimal b = new BigDecimal("123.456");
b.scale(),返回的就是3
注意点二
roundingMode是小数的保留模式。它们都是BigDecimal中的常量字段,有很多种,如
BigDecimal.ROUND_HALF_UP表示的就是4舍5入
注意点三
pubilc BigDecimal divide(BigDecimal divisor, int scale, int roundingMode)的意思是说:我用一个BigDecimal对象除以divisor后的结果,并且要求这个结果保留有scale个小数位,roundingMode表示的就是保留模式是什么,是四舍五入啊还是其它的
注意点四
对于一般add、subtract、multiply方法的小数位格式化如下
BigDecimal mData = new BigDecimal("9.655").setScale(2, BigDecimal.ROUND_HALF_UP);
System.out.println("mData=" + mData);
相关推荐
在Java编程语言中,BigDecimal是用于处理高精度和可配置精度的十进制数的类。在进行商业计算时,由于浮点数(double和float)存在精度问题,不能保证准确的结果,因此通常推荐使用BigDecimal来确保计算的精确性。本文...
Java中BigDecimal类的使用详解 Java中BigDecimal类是Java.math包中提供的一个API类,用于对超过16位有效位的数进行精确的运算。由于浮点数的精度问题,Java中浮点数的计算会失去一定的精确度。因此,使用BigDecimal...
在Java编程语言中,`BigDecimal` 类位于 `java.math` 包下,它提供了一种进行高精度和任意精度的十进制算术运算的方法。`BigDecimal` 是为那些需要精确数值计算的场景设计的,比如金融计算或会计应用,因为普通的 `...
BigDecimal 类是 Java 中的一种数值类型,主要用于处理超过 16 位有效数字的数值运算。该类提供了多种构造器和方法,用于创建和操作 BigDecimal 对象。 构造器 BigDecimal 类提供了四种构造器,用于创建不同的 ...
在实际应用中,需要对更大或者更小的数进行运算和处理。float和double只能用来做科学计算或者是工程计算,在商业计算中要用java.math.BigDecimal。BigDecimal所创建的是对象,我们不能使用传统的+、-、*、/等算术...
为了解决这个问题,开发者们引入了`BigDecimal`类库的概念,它在Java中被广泛使用,用于进行高精度的算术运算。本文将详细介绍JavaScript版的`BigDecimal`类库,以及如何在JavaScript环境中实现精确计算。 ...
根据提供的代码示例,我们可以更详细地了解如何在实际应用中使用 `BigDecimal`。 ```java import java.math.BigDecimal; public class Arith { // 默认精度 private static final int DEF_DIV_SCALE = 10; // ...
在Java编程语言中,BigDecimal是一种用于处理高精度数值的数据类型,尤其适用于金融计算等领域,因为它可以提供不受限的小数位数精度以及精确的数学运算能力。然而,在某些情况下,我们可能需要将BigDecimal类型的值...
综上所述,Java中保留两位小数的方法有很多种,选择哪种取决于具体的应用场景和需求。对于需要高精度计算的情况,推荐使用`BigDecimal`;而对于简单展示数据的需求,则可以选择`DecimalFormat`或`String.format`等...
在实际应用中,`BigDecimal`不仅可以用于基本的数学运算,还可以用于金融、财务等需要精确计算的场景。其灵活性和可配置性使得我们可以根据需求调整精度和舍入策略,避免了由于浮点数运算导致的不准确性。在处理大数...
在实际应用中,为了确保商业运算的精确性,建议始终使用`BigDecimal(String)`构造器来创建`BigDecimal`实例,并且谨慎处理类型转换。`BigDecimal`虽然提供了精确计算的能力,但它的性能相对较低,不适合大量快速计算...
在Java编程中,`BigDecimal`类是用于表示和操作大整数或高精度浮点数的。它在处理财务计算、精确数学运算等...在实际应用中,根据具体需求选择合适的方法,并合理处理可能出现的异常,可以提高代码的健壮性和可读性。
BigDecimal 类在 Java 中被设计用来处理高精度的浮点数运算,主要应用于财务、金融等领域,因为这些场景中对精度要求非常高。BigDecimal 提供了加法(add())、减法(subtract())、乘法(multiply())和除法...
总的来说,"js_bigdecimal_1_0_1.zip"为JavaScript开发者提供了一种解决大数精度问题的工具,使得在Web应用中进行精确计算成为可能。对于需要处理大量财务数据或需要精确计算的项目,这是一个非常有价值的库。
BigDecimal 是 Java 中一个用于处理金融和商业应用的类,其主要功能是提供高精度的数字计算。下面是关于 BigDecimal 的使用方法和注意事项: 1. 导包:在使用 BigDecimal 之前,需要导入 java.math.BigDecimal 包。...
在Java中,`BigDecimal` 类提供了对超过16位有效数字的十进制数进行精确算术运算的能力。它适用于金融计算、科学计算等场景,在这些场景中,使用浮点数(如 `float` 和 `double`)可能会因为精度丢失而导致错误的...
java.math 提供用于执行任意精度整数算法 (BigInteger) 和任意精度小数算法 (BigDecimal) 的类。 java.net 为实现网络应用程序提供类。 java.nio 定义作为数据容器的缓冲区,并提供其他 NIO 包的概述。 java.nio....
BigDecimal是Java提供的一个大数类,它可以用来进行精确的浮点数运算,避免了传统浮点数运算中可能出现的精度损失问题。在金融或会计系统中,对数据的精度要求很高,BigDecimal就成为首选的数据类型。 在...
BigDecimal 是 Java 中的一个类,它由任意精度的整数非标度值和 32 位的整数标度 (scale) 组成。它主要用于商业计算、银行存款数额等场合,需要提供完全精确的结果。 知识点 1:BigDecimal 的组成 BigDecimal 由...
在Java编程语言中,`BigInteger`和`BigDecimal`是两个重要的类,用于处理大整数和高精度浮点数运算。这两个类属于`java.math`包,为开发者提供了超越普通`int`、`long`以及`float`和`double`类型的数值计算能力。 `...