在 Java 中截断 Double

Rupam Yadav 2023年1月30日 2021年4月29日
  1. 在 Java 中使用 DecimalFormat 来截断双精度数
  2. 在 Java 中使用 BigDecimal 来截断双精度数
  3. 在 Java 中使用 Apache 通用库来截断小数
  4. 在 Java 中使用 java.lang.Math 来截断小数
在 Java 中截断 Double

在本文中,我们将研究如何在 Java 中将数字截断或舍入为 n 个小数点。Java 提供了两种基本类型来存储十进制值,即 double 和 float。建议使用 BigDecimal 类获取精确值或四舍五入。

在 Java 中使用 DecimalFormat 来截断双精度数

DecimalFormatNumberFormat 的子类,可以使用提供的格式化模式对十进制数字进行格式化。在下面的代码中,我们创建了一个 DecimalFormat 对象,该对象传递了合适的格式设置模式。我们可以在 decimatFormat 对象上调用 format()方法,并将我们的双变量 d 作为参数传递。

format() 方法返回一个被截断的字符串,如输出所示。

import java.text.DecimalFormat;
public class DecimalFormatting {
    public static void main(String args[]){
        double d = 9.4568982982989;
        String pattern = "#.###";
        DecimalFormat decimalFormat =  new DecimalFormat(pattern);
        String formattedDouble = decimalFormat.format(d);
        System.out.println("Formatted double d = "+formattedDouble);
    }
}

输出:

Formatted double d = 9.457

在 Java 中使用 BigDecimal 来截断双精度数

在 Java 中,BigDecimal 是不可变的,任意精度的带符号十进制数字。它提供对比例和精度的控制。我们创建了一个 BigDecimal 对象,该对象将 double 转换为字符串,从而避免了代表近似值的问题。

然后,我们在此 BigDecimal 对象 bd 上调用 setScale(int newScale, RoundingMode roundingMode) 方法,该方法有两个参数:要返回的 BigDecimal 的比例,另一个是要应用的舍入模式。RoundingMode.FLOOR 模式向负无穷大舍入。

public class DecimalFormatting {
    public static void main(String args[]){
        double d = 9.4568982982989;
        BigDecimal bd = new BigDecimal(String.valueOf(d));
        BigDecimal rounded = bd.setScale(2,RoundingMode.FLOOR);
        System.out.println("BigDecimal rounded off : "+rounded);
    }
}

输出:

BigDecimal rounded off : 9.45

在 Java 中使用 Apache 通用库来截断小数

我们可以通过该库实现相同的目标,该库的 maven 依赖关系在下面给出。

<dependency>
    <groupId>org.apache.commons</groupId>
    <artifactId>commons-math3</artifactId>
    <version>3.5</version>
</dependency>

我们可以使用该库中的 Precision.round() 方法来格式化小数。此方法有两个参数,一个是要格式化的小数变量,另一个是小数位。小数点后需要 4 位数字;因此,这就是我们需要的规模。输出显示十进制数字被截断。

import org.apache.commons.math3.util.Precision;
public class DecimalFormatting {
    public static void main(String args[]){
        double d = 9.4568982982989;
        double doubleP = Precision.round(d,4);
        System.out.println("Precision rounded off : "+doubleP);
    }
}

输出:

Precision rounded off : 9.4569

在 Java 中使用 java.lang.Math 来截断小数

这是在 Java 中舍入十进制数字的另一种方法。Math.pow() 通过乘以 10n来控制 n 个小数位数。我们使用此方法创建一个双变量 scale,该变量带有两个参数,以 10 为底和以 3 为底。

Java 中的 Math.round() 用于将数字四舍五入到最接近的整数。这是通过将数字加 1/2,说出结果的底限并将结果转换为整数数据类型来完成的。不建议使用此方法,因为它有时会错误地截断该值。

public class DecimalFormatting {
    public static void main(String args[]){
         double d = 9.4568982982989;
         double scale = Math.pow(10, 3);
         double doubleM1 = Math.round(d*scale)/scale;
         System.out.println("Math1 Rounded off: "+doubleM1);
    }
}

输出:

Math Rounded off: 9.45
Math1 Rounded off: 9.457
Author: Rupam Yadav
Rupam Yadav avatar Rupam Yadav avatar

Rupam Saini is an android developer, who also works sometimes as a web developer., He likes to read books and write about various things.

LinkedIn

相关文章 - Java Double