`
dreamer_0924
  • 浏览: 180461 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论

BigDecimal divide方法结果为无限小数问题

阅读更多
10/3=3.3333333333333333..............
	public static void main(String[] args) {
		BigDecimal a = new BigDecimal("10");
		BigDecimal o = new BigDecimal("3");
		System.out.print(a.divide(o).setScale(2, BigDecimal.ROUND_DOWN).doubleValue());
	}

Exception in thread "main" java.lang.ArithmeticException: Non-terminating decimal expansion; no exact representable decimal result.
	at java.math.BigDecimal.divide(BigDecimal.java:1514)
	at test.main(test.java:8)

解决方法:
	public static void main(String[] args) {
		BigDecimal a = new BigDecimal("10");
		BigDecimal o = new BigDecimal("3");
		System.out.print(a.divide(o,2, BigDecimal.ROUND_DOWN).doubleValue());		
	}

输出:3.33


需要注意的地方:
	   /**
	   * (1)BigInteger和BigDecimal都是不可变(immutable)的,在进行每一步运算时,都会产生一个新的对象,由于创建对象会引起开销,
	   * 它们不适合于大量的数学计算,应尽量用long,float,double等基本类型做科学计算或者工程计算。
	   * 设计BigInteger和BigDecimal的目的是用来精确地表示大整数和小数,使用于在商业计算中使用。
	   * (2)BigDecimal有4个够造方法,其中的两个用BigInteger构造,另一个是用double构造,还有一个使用String构造。
	   * 应该避免使用double构造BigDecimal,因为:有些数字用double根本无法精确表示,传给BigDecimal构造方法时就已经不精确了。
	   * 比如,new BigDecimal(0.1)得到的值是0.1000000000000000055511151231257827021181583404541015625。
	   * 使用new BigDecimal("0.1")得到的值是0.1。因此,如果需要精确计算,用String构造BigDecimal,避免用double构造,尽管它看起来更简单!
	   * (3)equals()方法认为0.1和0.1是相等的,返回true,而认为0.10和0.1是不等的,结果返回false。
	   * 方法compareTo()则认为0.1与0.1相等,0.10与0.1也相等。所以在从数值上比较两个BigDecimal值时,应该使用compareTo()而不是 equals()。
	   * (4)另外还有一些情形,任意精度的小数运算仍不能表示精确结果。例如,1除以9会产生无限循环的小数 .111111...。
	   * 出于这个原因,在进行除法运算时,BigDecimal可以让您显式地控制舍入。
	   */




分享到:
评论
发表评论

文章已被作者锁定,不允许评论。

相关推荐

    java中BigDecimal的操作方法

    在进行商业计算时,由于浮点数(double和float)存在精度问题,不能保证准确的结果,因此通常推荐使用BigDecimal来确保计算的精确性。本文将深入探讨BigDecimal的基本操作、应用场景及注意事项。 首先,创建...

    JS的高精度计算(BigDecimal)

    你是否因为JS端的小数计算的精度不足而发愁过呢 其实有个不错的资源可以利用。 引用附件的JS,就可以轻松搞定JS的计算问题了。...alert(new BigDecimal("10.00").divide(new BigDecimal("3E+10"))); } //--> </SCRIPT>

    BigDecimal使用

    6. 精确的除法运算:使用 BigDecimal 的 divide 方法可以进行精确的除法运算,例如将两个 BigDecimal 对象相除并返回结果。需要注意的是,除法运算可能会出现无限循环的小数,为了避免这种情况,可以使用 scale 参数...

    java BigDecimal操作

    分割除法时需注意,由于可能会出现无限循环小数,`divide()`方法需要指定舍入模式,例如`RoundingMode.HALF_UP`表示四舍五入。 BigDecimal还提供了比较操作,如`compareTo()`方法,用于比较两个BigDecimal值的大小...

    bigdecimal

    4. **除法**: 使用 `divide()` 方法,需要注意的是除法可能产生无限循环小数,因此通常需要指定舍入模式和小数点后的保留位数。 #### 四、示例代码解析 根据提供的代码示例,我们可以更详细地了解如何在实际应用中...

    javascript版BigDecimal类库

    总的来说,JavaScript版`BigDecimal`类库为开发者提供了一种解决JavaScript精度问题的工具,使得在进行金融计算、科学计算或其他需要高精度计算的场合下,能够得到准确的结果。通过学习和应用这个库,开发者可以更好...

    BigDecimal.js.zip

    这个库提供了一个名为`BigDecimal`的数据类型,用于实现大数运算,确保结果的精度不受损失。 "BigDecimal.js.zip"是一个压缩包,其中包含了"BigDecimal-all-last.min.js"文件。这个文件是BigDecimal.js库的最小化...

    BigDecimal的计算

    合理使用 `BigDecimal` 及其提供的各种方法,可以帮助我们避免因浮点数精度限制而产生的误差问题。此外,通过设置不同的舍入模式,还可以满足不同场景下的需求。在实际开发中,理解并熟练掌握 `BigDecimal` 的使用是...

    BigDecimal计算

    例如,数字`12345`在`BigDecimal`中可以表示为`1234500`,缩放因子为2,表示有两位小数。 下面是一些关于`BigDecimal`计算的关键知识点: 1. **构造方法**:`BigDecimal`可以通过字符串、整数、长整数或`...

    MyEditTextApplication输入框BigDecimal计算价格

    本项目“MyEditTextApplication”专注于使用BigDecimal进行输入框内的价格计算,确保计算结果的高度精确,尤其是在处理小数点后的多位数字时。 BigDecimal是Java提供的一个大数类,它可以用来进行精确的浮点数运算...

    详谈Java中BigDecimal的一个除法异常

    no exact representable decimal result." 提示我们,当前的除法运算会导致无限循环的小数部分,Java无法为这样的结果找到一个精确的`BigDecimal`表示。为了解决这个问题,我们需要在调用`divide`方法时指定商的...

    Bigdecimal.js

    `BigDecimal`类库提供了丰富的操作方法,包括加法(add)、减法(subtract)、乘法(multiply)、除法(divide)、求余(remainder)、比较(compare)等,这些方法都是为了确保在进行高精度运算时的准确无误。...

    Java中BigDecimal的加减乘除、比较大小与使用注意事项

    4. **除法**:使用`divide()`方法进行除法,注意可能会有舍入问题,需要指定舍入模式,如`RoundingMode.HALF_UP`。 ```java bignum3 = bignum1.divide(bignum2, RoundingMode.HALF_UP); ``` 结果将是`2`。 ### ...

    java-BigInteger-BigDecimal类源码

    2. **精度控制**:`BigDecimal`的精度可以通过构造函数或者`setScale()`方法进行设置,以控制小数部分的位数。 3. **运算符重载**:`BigDecimal`提供了与`BigInteger`类似的算术操作,但还包括了除法、比较和舍入...

    BigDecimal加减乘除计算

    在进行高精度计算时,BigDecimal 避免了浮点数计算的精度问题,提供了更精确的结果。需要注意的是,所有涉及到 BigDecimal 的运算都会创建新的对象,所以频繁操作可能会带来性能影响。为了优化性能,可以使用 `...

    关于java中BigDecimal的简介(csdn)————程序.pdf

    `BigDecimal`还提供了多种其他方法,如`compareTo()`用于比较两个`BigDecimal`的大小,`scale()`获取小数部分位数,`stripTrailingZeros()`去除尾随零,`toPlainString()`返回不带科学计数法的字符串表示等。...

    BigDecimal基本运算介绍

    `BigDecimal` 类是 Java 中用于高精度浮点数计算的关键工具,主要解决 `float` 和 `double` 类型在处理货币、财务等需要精确计算场景时存在的精度问题。`BigDecimal` 的运算方式与基本数据类型有所不同,因为它涉及...

    double保留小数

    - 使用`divide`方法将`BigDecimal`对象除以1,并指定保留的小数位数`scale`以及舍入模式`ROUND_HALF_UP`。 - 最后返回处理后的`double`值。 2. **运行结果**: - 当输入`2.123123`和`4`时,输出为`2.1231`。 - ...

    java代码-BigDecimal 四舍五入保留2位小数. 金额从单位分转成单位元

    通常,`main`方法是程序的入口点,它会创建BigDecimal对象,执行四舍五入和转换操作,并可能打印结果。 5. README.txt文件: 这个文件通常包含了项目或代码的说明,可能包括如何运行代码、代码的目的、作者信息...

    BigDecimal详解、代码示例和经常遇到的坑

    与基本数据类型`float`或`double`相比,`BigDecimal`能够提供更为准确的计算结果,避免因浮点数计算导致的精度丢失问题。 **主要特点:** 1. **任意精度**:`BigDecimal`可以存储和处理非常大的数值以及任意长度的...

Global site tag (gtag.js) - Google Analytics