工具类如下:
package com.yusj.web.utils; import java.math.BigDecimal; /** * * @ClassName: ArithUtils * @Description: 数学计算工具类 * 由于Java的简单类型不能够精确的对浮点数进行运算,这个工具类提供精 确的浮点数运算,包括加减乘除和四舍五入。 * @author shaojian.yu * @date 2015年11月9日 下午5:44:12 * */ public class ArithUtils { // 默认除法运算精度 private static final int DEF_DIV_SCALE = 10; // 这个类不能实例化 private ArithUtils() { } /** * * @Title:add * @Description: 提供精确的加法运算。 * @author shaojian.yu * @date 2015年11月9日 下午5:46:55 * @param v1 被加数 * @param v2 加数 * @return 两个参数的和 */ public static double add(double v1, double v2) { BigDecimal b1 = new BigDecimal(Double.toString(v1)); BigDecimal b2 = new BigDecimal(Double.toString(v2)); return b1.add(b2).doubleValue(); } /** * * @Title:sub * @Description: 提供精确的减法运算。 * @author shaojian.yu * @date 2015年11月9日 下午5:47:24 * @param v1 被减数 * @param v2 减数 * @return 两个参数的差 */ public static double sub(double v1, double v2) { BigDecimal b1 = new BigDecimal(Double.toString(v1)); BigDecimal b2 = new BigDecimal(Double.toString(v2)); return b1.subtract(b2).doubleValue(); } /** * * @Title:mul * @Description: 提供精确的乘法运算。 * @author shaojian.yu * @date 2015年11月9日 下午5:47:51 * @param v1 被乘数 * @param v2 乘数 * @return 两个参数的积 */ public static double mul(double v1, double v2) { BigDecimal b1 = new BigDecimal(Double.toString(v1)); BigDecimal b2 = new BigDecimal(Double.toString(v2)); return b1.multiply(b2).doubleValue(); } /** * * @Title:div * @Description: 提供(相对)精确的除法运算,当发生除不尽的情况时,精确到小数点以后10位,以后的数字四舍五入。 * @author shaojian.yu * @date 2015年11月9日 下午5:48:10 * @param v1 被除数 * @param v2 除数 * @return 两个参数的商 */ public static double div(double v1, double v2) { return div(v1, v2, DEF_DIV_SCALE); } /** * * @Title:div * @Description: 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指定精度,以后的数字四舍五入。 * @author shaojian.yu * @date 2015年11月9日 下午5:48:50 * @param v1 被除数 * @param v2 除数 * @param scale 表示需要精确到小数点以后几位。 * @return 两个参数的商 */ public static double div(double v1, double v2, int scale) { if (scale < 0) { throw new IllegalArgumentException( "The scale must be a positive integer or zero"); } BigDecimal b1 = new BigDecimal(Double.toString(v1)); BigDecimal b2 = new BigDecimal(Double.toString(v2)); return b1.divide(b2, scale, BigDecimal.ROUND_HALF_UP).doubleValue(); } /** * * @Title:round * @Description: 提供精确的小数位四舍五入处理。 * @author shaojian.yu * @date 2015年11月9日 下午5:49:13 * @param v 需要四舍五入的数字 * @param scale 小数点后保留几位 * @return 四舍五入后的结果 */ public static double round(double v, int scale) { if (scale < 0) { throw new IllegalArgumentException( "The scale must be a positive integer or zero"); } BigDecimal b = new BigDecimal(Double.toString(v)); BigDecimal one = new BigDecimal("1"); return b.divide(one, scale, BigDecimal.ROUND_HALF_UP).doubleValue(); } };
相关推荐
总的来说,Java中解决浮点数精度问题的关键是使用BigDecimal类,并且要注意构造方法的选择,避免在转换过程中引入额外的精度损失。在编写涉及金融计算或需要高度精确性的程序时,使用BigDecimal是最佳实践。同时,...
3. **使用库**:有一些库,如提供的`DoubleCount.js`,可以帮助处理浮点数精度问题。`DoubleCount.js`可能提供了更精确的浮点数计算方法,或者提供了方便的比较和格式化工具。 ```javascript // 引入DoubleCount....
在Java编程语言中,浮点数的运算涉及到的是数值计算,特别是小数部分的处理。...通过合理使用`float`、`double`以及`BigDecimal`,我们可以根据实际需求平衡精度和性能,从而避免因浮点数运算带来的潜在问题。
浮点数精度问题在计算机科学和编程中是一个常见的主题,特别是在进行数学计算和数据处理时。浮点数在计算机中的表示并非像整数那样精确,这源于它们的二进制表示方式。本篇文章将深入探讨浮点数精度问题的原因、影响...
为了克服这个问题,Java提供了`java.math.BigDecimal`类,它提供了一种方法来进行高精度的十进制计算,从而避免浮点运算中的精度问题。 描述中的"Java实现的浮点类的精确计算"很可能就是指一个自定义的工具类,该类...
总的来说,理解和熟练运用BigDecimal是每个Java开发者必备的技能之一,特别是在处理货币计算、财务计算等场景时,能够避免因为浮点数精度问题导致的错误。在使用BigDecimal时,一定要注意其性能开销,因为它比基本的...
本文将详细介绍Java中的 `double` 类型精度问题,并提供几种解决方法。 #### 一、Java Double 精度丢失的原因 1. **二进制表示限制**:`double` 类型基于IEEE 754标准的双精度格式,使用64位来表示一个浮点数。...
### Java中实现浮点数的精确计算 在Java编程中,使用`float`和`double`类型...通过上述方法,可以在Java中实现浮点数的精确计算,解决因精度问题导致的误差。在实际开发中,根据应用场景选择合适的解决方案非常重要。
总结来说,Java中的浮点数计算精度损失是由浮点数的二进制表示方式决定的,而要解决这个问题,最有效的方法是使用`BigDecimal`类进行高精度计算。在编程时,应根据实际需求选择合适的数值类型和计算策略,确保计算...
Java.math 包下计算浮点数和整数...Java.math 包下计算浮点数和整数的类的实例非常重要, BigInteger 和 BigDecimal 两个类是 Java.math 包中的核心类,它们提供了高精度的整数和浮点数运算,用于解决复杂的数学问题。
为了解决这个问题,Java提供了`BigDecimal`类,它能够进行高精度的浮点数运算,保证结果的精确性。以下是使用`BigDecimal`进行浮点数运算的例子: ```java BigDecimal bd1 = new BigDecimal("0.1"); BigDecimal bd2...
Java中的BigDecimal是一种高精度的数据类型,它可以用来表示非常大的整数和小数,提供了丰富的数学运算功能。下面我们将对Java中BigDecimal的基本运算进行详细的介绍。 构造方法 BigDecimal有四种构造方法,但是...
在进行商业计算时,由于浮点数(double和float)存在精度问题,不能保证准确的结果,因此通常推荐使用BigDecimal来确保计算的精确性。本文将深入探讨BigDecimal的基本操作、应用场景及注意事项。 首先,创建...
BigDecimal类是一个大小数操作类,可以用来对超过16位有效位的数据进行精确的运算,在这里我们使用BigDecimal类来解决浮点数计算产生的精度丢失问题。 精度问题 在这里我们讨论一个问题:3 – 2.7 == 0.3 的值是什么...
合理使用 `BigDecimal` 及其提供的各种方法,可以帮助我们避免因浮点数精度限制而产生的误差问题。此外,通过设置不同的舍入模式,还可以满足不同场景下的需求。在实际开发中,理解并熟练掌握 `BigDecimal` 的使用是...
Java 双精度浮点数精度问题解决方案 Java 中的双精度浮点数(double)类型在进行运算时经常出现精度丢失的问题,这是由于双...使用 BigDecimal 类可以解决 Java 中的双精度浮点数精度问题,从而避免程序处理流程出错。
在Java编程语言中,`BigInteger`和`BigDecimal`是两个重要的类,它们分别用于处理大整数和高精度浮点数。这两个类位于`java.math`包下,为开发者提供了超越基本数据类型(如int、long和double)的计算能力。在深入...
解决精度问题的方法有很多,如使用更高精度的数据类型(如Java中的`BigDecimal`),或者使用特定的算法进行浮点数比较。在进行浮点数计算时,可以设定一个容差值(epsilon),只要两个数的差的绝对值小于这个容差,...
在进行高精度计算时,BigDecimal 避免了浮点数计算的精度问题,提供了更精确的结果。需要注意的是,所有涉及到 BigDecimal 的运算都会创建新的对象,所以频繁操作可能会带来性能影响。为了优化性能,可以使用 `...
3. 使用 `BigDecimal.valueOf(0.0)` 创建,同样由于浮点数精度问题,`equals()` 返回 `false`。 4. 使用 `BigDecimal.valueOf(0.0).setScale(1)` 创建并设置精度为1,即使数值相同,但由于设置了不同的标度,`equals...