迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > Java >

在 Java 中截断 Double

作者:迹忆客 最近更新:2023/09/17 浏览次数:

在本文中,我们将研究如何在 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

上一篇:在 Java 中将 Double 转换为浮点数

下一篇:没有了

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

在 Java 中将 Double 转换为浮点数

发布时间:2023/09/20 浏览次数:189 分类:Java

本文讨论如何在 Java 中将双精度值转换为浮点数。在本文中,我们将学习如何在 Java 中将双精度值转换为浮点数。Double 和 float 类型用于在 Java 中存储实数或浮点数,但 double 数据类型比 float 更

Java 中的浮点数和 Double 数据类型

发布时间:2023/09/20 浏览次数:148 分类:Java

本文重点介绍 Java 中的 float 和 double 数据类型 Float 和 double 数据类型用于在 Java 中存储实数或浮点数,但 double 数据类型比 float 更精确。double 是浮点数的默认数据类型。

在 Java 中比较双精度数

发布时间:2023/09/20 浏览次数:116 分类:Java

了解如何在 Java 中比较双精度数。本文将告诉你如何在 Java 中比较双精度数。有一些内置方法可以比较双精度数。本指南中解释了这些方法。

Java 中的双精度

发布时间:2023/09/20 浏览次数:63 分类:Java

本文介绍了 double 及其在 Java 中的用法。本文介绍了 double 及其在 Java 中的用法。Double 是 Java 中用于存储浮点值的数据类型。

在 Java 中将 Long 转换为 Double

发布时间:2023/09/20 浏览次数:187 分类:Java

本文介绍如何在 Java 中将 long 值转换为 double 值。本文介绍如何在 Java 中将 long 类型转换为 double 类型。在 Java 中,long 和 double 都用于存储数值。long 用于存储非浮点值,而 double 用于存储浮点值

如何在 Java 中将函数作为参数传递

发布时间:2023/09/20 浏览次数:118 分类:Java

本文介绍了在 Java 中把一个函数作为参数传递给另一个函数的方法。本文将讨论如何在 Java 中把一个函数作为参数传递给另一个函数。我们将讨论两种不同的方法来传递一个函数作为 Java 中的参

Java 可选参数

发布时间:2023/09/20 浏览次数:83 分类:Java

本文介绍如何在 Java 中使用可选参数 在 Java 类中,当我们设计一个方法或函数时,一些参数可能是其执行的可选参数。

修复 Java 无效方法声明;需要返回类型

发布时间:2023/09/20 浏览次数:174 分类:Java

如何修复无效的方法声明; Java 中需要的返回类型。无效的方法声明;需要返回类型。当你声明一个函数并且没有提及它的返回类型时,Java 中会发生这种类型的错误。

在 Java 中创建回调函数

发布时间:2023/09/20 浏览次数:83 分类:Java

本教程演示如何在 Java 中创建和使用回调函数。我们使用接口来实现 Java 中的回调,因为它不支持函数指针。本文介绍如何在 Java 中创建和使用回调函数。

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便