BigDecimal类处理高精度计算

发布时间:2026/6/30 1:53:18
BigDecimal类处理高精度计算 Java在java.math包中提供的API类BigDecimal用来对超过16位有效位的数进行精确的运算。双精度浮点型变量double可以处理16位有效数但在实际应用中可能需要对更大或者更小的数进行运算和处理。一般情况下对于那些不需要准确计算精度的数字我们可以直接使用Float和Double处理但是Double.valueOf(String) 和Float.valueOf(String)会丢失精度。所以开发中如果我们需要精确计算的结果则必须使用BigDecimal类来操作。一、BigDecimal简介BigDecimal 由任意精度的整数非标度值 和32 位的整数标度 (scale) 组成。如果为零或正数则标度是小数点后的位数。如果为负数则将该数的非标度值乘以10的负scale 次幂。因此BigDecimal表示的数值是(unscaledValue × 10-scale)。二、float、double转换为BigDecimal1、参数类型为double的构造方法的结果有一定的不可预知性。有人可能认为在Java中写入newBigDecimal(0.1)所创建的BigDecimal正好等于 0.1非标度值 1其标度为 1但是它实际上等于0.1000000000000000055511151231257827021181583404541015625。这是因为0.1无法准确地表示为 double或者说对于该情况不能表示为任何有限长度的二进制小数。这样传入到构造方法的值不会正好等于 0.1虽然表面上等于该值。2、另一方面String 构造方法是完全可预知的写入 newBigDecimal(0.1) 将创建一个 BigDecimal它正好等于预期的 0.1。因此比较而言通常建议优先使用String构造方法。3、当double必须用作BigDecimal的源时请注意此构造方法提供了一个准确转换它不提供与以下操作相同的结果先使用Double.toString(double)方法然后使用BigDecimal(String)构造方法将double转换为String。要获取该结果请使用staticvalueOf(double)方法。三、注意事项1.商业计算使用BigDecimal。2.尽量使用参数类型为String的构造函数。3. BigDecimal都是不可变的immutable的在进行每一步运算时都会产生一个新的对象所以在做加减乘除运算时千万要保存操作后的值。4.我们往往容易忽略JDK底层的一些实现细节导致出现错误需要多加注意。参考文章https://blog.csdn.net/freejs/article/details/84390951https://blog.csdn.net/qq_35525955/article/details/81317898https://www.sxt.cn/math/java_math_bigdecimal.htmlhttps://cloud.tencent.com/developer/article/1514160