在 Java 中截断 Double
在本文中,我们将研究如何在 Java 中将数字截断或舍入为 n 个小数点。Java 提供了两种基本类型来存储十进制值,即 double 和 float。建议使用 BigDecimal
类获取精确值或四舍五入。
在 Java 中使用 DecimalFormat
来截断双精度数
DecimalFormat
是 NumberFormat
的子类,可以使用提供的格式化模式对十进制数字进行格式化。在下面的代码中,我们创建了一个 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 转换为浮点数
发布时间: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 浏览次数:174 分类:Java
-
如何修复无效的方法声明; Java 中需要的返回类型。无效的方法声明;需要返回类型。当你声明一个函数并且没有提及它的返回类型时,Java 中会发生这种类型的错误。
在 Java 中创建回调函数
发布时间:2023/09/20 浏览次数:83 分类:Java
-
本教程演示如何在 Java 中创建和使用回调函数。我们使用接口来实现 Java 中的回调,因为它不支持函数指针。本文介绍如何在 Java 中创建和使用回调函数。