`
simplehumn
  • 浏览: 186498 次
  • 性别: Icon_minigender_1
  • 来自: 石家庄
社区版块
存档分类
最新评论

BigDecimal类的应用,java实现精确运算

阅读更多
浮点数的数学运算在通常情况下是不精确的,这种情况普遍存在于几乎所有的编程语言中,大数字类BigDecimal可以实现任意精度的数学运算。
注意:BigDecimal计算时需要把Double类型的值转换为String类型。
import java.math.BigDecimal;
         //加法运算
	public static double add(double x, double y) {
	   BigDecimal bigX = new BigDecimal(x + "");
	   BigDecimal bigY = new BigDecimal(y + "");
	   return bigX.add(bigY).doubleValue();
	}
	//减法运算
	public static double subtract(double x, double y) {
	   BigDecimal bigX = new BigDecimal(x + "");
	   BigDecimal bigY = new BigDecimal(y + "");
	   return bigX.subtract(bigY).doubleValue();
	}
	//乘法运算
	public static double multiply(double x, double y) {
	   BigDecimal bigX = new BigDecimal(x + "");
	   BigDecimal bigY = new BigDecimal(y + "");
	   return bigX.multiply(bigY).doubleValue();
	}
	//除法运算
	public static double divide(double x, double y) {
	   if (y == 0) {
		   System.err.println("错误:被除数不能为0!");
	    	return 0;
	   }else{
		   BigDecimal bigX = new BigDecimal(x + "");
		   BigDecimal bigY = new BigDecimal(y + "");
		   return bigX.divide(bigY, 3, BigDecimal.ROUND_HALF_EVEN).doubleValue();
	   }	
         }

BigDecimal divide(BigDecimal divisor, int scale, int roundingMode)
给divide设置精确的小数点divide(xxxxx,2, BigDecimal.ROUND_HALF_EVEN) ,否则,遇到除不尽的值时会报如下异常:
java.lang.ArithmeticException: Non-terminating decimal expansion; no exact representable decimal result. at java.math.BigDecimal.divide(Unknown Source) 

分享到:
评论

相关推荐

    BigDecimal类

    BigDecimal 类是 Java 中的一种数值类型,主要用于处理超过 16 位有效数字的数值运算。该类提供了多种构造器和方法,用于创建和操作 BigDecimal 对象。 构造器 BigDecimal 类提供了四种构造器,用于创建不同的 ...

    java-BigInteger-BigDecimal类源码

    通过阅读`BigInteger.java`和`BigDecimal.java`的源代码,我们可以深入了解这两个类的实现细节,包括它们如何存储和操作数值,以及各种算法的实现。源代码分析可以帮助我们理解内部工作原理,提高性能优化的能力,...

    BigDecimal 加减乘除运算

    Java中BigInteger的数学运算,BigDecimal 加减乘除运算,Java在java.math包中提供的API类BigDecimal,用来对超过16位有效位的数进行精确的运算。双精度浮点型变量double可以处理16位有效数。在实际应用中,需要对更大...

    BigDecimal工具类.docx

    BigDecimal工具类是Java中用于高精确处理常用数学运算的工具类。该工具类提供了多种精确的数学运算方法,包括加法、减法、乘法和除法等。 在BigDecimal工具类中,我们可以看到多个重载的方法,例如add方法和sub方法...

    Java中BigDecimal类的简单用法

    此外,BigDecimal类还支持舍入模式(RoundingMode),在进行除法运算时,如果需要四舍五入或者按照特定规则处理余数,可以通过setScale(int newScale, RoundingMode roundingMode)方法来实现。总之,Java中的...

    Java对BigDecimal常用方法的归类(加减乘除).doc

    Java 中的 BigDecimal 类提供了对浮点数的精确运算,包括加减乘除和四舍五入等操作。在 Java 中,简单类型不能够精确地对浮点数进行运算,因此需要使用 BigDecimal 类来提供精确的浮点数运算。 加法运算 在 Java ...

    Java中BigDecimal类的使用详解

    Java中BigDecimal类是Java.math包中提供的一个API类,用于对超过16位有效位的数进行精确的运算。由于浮点数的精度问题,Java中浮点数的计算会失去一定的精确度。因此,使用BigDecimal类可以避免浮点数的精度问题,...

    java BigDecimal操作

    在Java编程语言中,BigDecimal类是用于处理高精度、大范围浮点数的工具,它在需要精确计算的场景下非常关键。BigDecimal提供了避免浮点数运算中的精度损失的方法,适用于金融、会计等对精度有严格要求的领域。这篇...

    Java实现的浮点类的精确计算

    描述中的"Java实现的浮点类的精确计算"很可能就是指一个自定义的工具类,该类可能封装了`BigDecimal`的使用,或者使用其他算法来实现浮点数的精确运算。这样的工具类通常会包含一系列静态方法,如加法、减法、乘法、...

    Java Bigdecimal使用原理详解

    BigDecimal类位于java.math类包下,提供了多种构造函数和方法来实现精确计算。 首先,我们来看下如何构造一个BigDecimal对象。它的构造函数很多,这里挑选最常用的两个来演示一下:一个就是BigDecimal(double val)...

    java中BigDecimal的操作方法

    在Java编程语言中,BigDecimal是用于处理高精度和可配置精度的十进制数的类。在进行商业计算时,由于浮点数(double和float)存在精度问题,不能保证准确的结果,因此通常推荐使用BigDecimal来确保计算的精确性。本文...

    使用BigDecimal进行精确运算(实现加减乘除运算)

    使用BigDecimal进行精确运算的步骤如下: 1. **创建BigDecimal对象**:你可以通过传入String表示的数值来创建BigDecimal对象,或者使用`BigDecimal.valueOf()`静态方法,将基本类型(如double)转换为BigDecimal。...

    【Java】BigDecimal实现加减乘除运算代码

    在Java编程中,进行高精度的数学计算时,通常会使用`java.math.BigDecimal`类,因为Java中的简单数据类型如`float`和`double`在处理大数或精确计算时可能会出现误差。`BigDecimal`类提供了加减乘除等运算方法,确保...

    BigDecimal使用

    BigDecimal 是 Java 中一个用于处理金融和商业应用的类,其主要功能是提供高精度的数字计算。下面是关于 BigDecimal 的使用方法和注意事项: 1. 导包:在使用 BigDecimal 之前,需要导入 java.math.BigDecimal 包。...

    Java的数学运算处理类讲解代码(BigDecimal、Math、Random、DecimalFormat类全部操作方法API)

    这个源码资源是一个讲解数学计算处理类的示例项目,旨在帮助开发者理解和使用Java中的数学计算相关类库。该项目包含详细的代码示例和注释,涵盖了以下几个主要的数学计算处理类:BigDecimal、Math、Random和...

    Java BigDecimal使用及基本运算(推荐)

    BigDecimal 类在 Java 中是用于处理高精度和大数值计算的,它确保了在计算过程中不会因为浮点数的精度问题而导致结果错误。由于 double 和 float 类型在处理大数或需要绝对精确计算的场景下存在精度损失,因此 ...

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

    在Java编程中,当涉及到需要精确数值计算的场景时,我们通常会使用`BigDecimal`类。这是因为`float`和`double`类型虽然适用于科学计算和工程计算,但它们基于二进制浮点运算,不能保证完全精确的结果。而`BigDecimal...

    java实现大数加法(BigDecimal)的实例代码

    与Java中的`int`, `long`, `float`, `double`等基本类型不同,`BigDecimal`不依赖于机器的浮点数表示,因此可以进行精确的算术运算,避免了浮点数运算常见的精度损失问题。 在给定的实例代码中,我们首先创建两个`...

    Java使用BigDecimal进行运算封装的实际案例

    BigDecimal是Java中一个用于处理精确数字计算的类,它提供了多种数学运算方法,如加法、减法、乘法、除法等。 在实际项目中,经常需要对金额进行计算,例如计算总额、计算税额等。在这种情况下,使用BigDecimal可以...

    Java BigDecimal详解_动力节点Java学院整理

    他们执行二进制浮点运算,这是为了在广域数值范围上提供较为精确的快速近似计算而精心设计的。然而,它们没有提供完全精确的结果,所以不应该被用于要求精确结果的场合。但是,商业计算往往要求结果精确,例如银行...

Global site tag (gtag.js) - Google Analytics