java中float,double利用BigDecimal运算

简介:

一、发现问题
float、double两种基本类型在运算的时候容易引起精度丢失。以float为例说明。
public static void main(String[] args) {
  float x = 1.0f;
  float y = 0.8f;
  float z = x - y;
  System.out.println(z);
}
结果是0.19999999


二、解决办法
利用java.math中的BigDecimal类进行操作
public static void main(String[] args) {
  float x = 1.0f;
  float y = 0.8f;

  BigDecimal x1 = new BigDecimal(Float.toString(x));
  BigDecimal x2 = new BigDecimal(Float.toString(y));
  float z = x1.subtract(x2).floatValue(); 
  System.out.println(z);
}
结果是0.2


三、注意点
注意点1
new BigDecimal(...)填写构造函数的时候,一定要使用String,而不要使用float或者double,否则同样会引起精度丢失。

注意点2
public static void main(String[] args) {
  float x = 1.0f;
  float y = 0.8f;
  BigDecimal x1 = new BigDecimal(Float.toString(x));
  BigDecimal x2 = new BigDecimal(Float.toString(y));
  x1.subtract(x2);
  System.out.println(x1);
}
x1仍然是1.0,因为不是引用类型。正确的是如下写法:

public static void main(String[] args) {
  float x = 1.0f;
  float y = 0.8f;
  BigDecimal x1 = new BigDecimal(Float.toString(x));
  BigDecimal x2 = new BigDecimal(Float.toString(y));
  x1 = x1.subtract(x2);
  System.out.println(x1);
}

本文转自IT徐胖子的专栏博客51CTO博客,原文链接http://blog.51cto.com/woshixy/1243197如需转载请自行联系原作者


woshixuye111

相关文章
|
24天前
|
存储 Java
Java基础(二):原码、反码、补码及进制之间的运算
Java基础(二):原码、反码、补码及进制之间的运算
Java基础(二):原码、反码、补码及进制之间的运算
|
6月前
|
Java
【Java】Math、System、RunTime、BigDecimal类常用方法
【Java】Math、System、RunTime、BigDecimal类常用方法
|
3月前
|
Java
Java项目中高精度数值计算:为何BigDecimal优于Double
在Java项目开发中,涉及金额计算、面积计算等高精度数值操作时,应选择 `BigDecimal` 而非 `Double`。`BigDecimal` 提供任意精度的小数运算、多种舍入模式和良好的可读性,确保计算结果的准确性和可靠性。例如,在金额计算中,`BigDecimal` 可以精确到小数点后两位,而 `Double` 可能因精度问题导致结果不准确。
|
4月前
|
安全 Java
java BigDecimal 的赋值一个常量
在 Java 中,`BigDecimal` 是一个用于精确计算的类,特别适合处理需要高精度和小数点运算的场景。如果你需要给 `BigDecimal` 赋值一个常量,可以使用其静态方法 `valueOf` 或者直接通过字符串构造函数。 以下是几种常见的方法来给 `BigDecimal` 赋值一个常量: ### 使用 `BigDecimal.valueOf` 这是推荐的方式,因为它可以避免潜在的精度问题。 ```java import java.math.BigDecimal; public class BigDecimalExample { public static void
137 4
|
6月前
|
Java
【Java基础面试十一】、int和Integer有什么区别,二者在做==运算时会得到什么结果?
这篇文章解释了Java中`int`基本数据类型和其包装类`Integer`之间的区别,并指出在进行`==`运算时,`Integer`会拆箱为`int`类型,然后比较它们的值是否相等。
【Java基础面试十一】、int和Integer有什么区别,二者在做==运算时会得到什么结果?
|
6月前
|
Java
【Java基础面试十】、何对Integer和Double类型判断相等?
这篇文章讨论了如何在Java中正确比较`Integer`和`Double`类型的值,指出不能直接使用`==`操作符比较不同类型,而应该将它们转换为相同的基本数据类型(如`double`)后进行比较。
【Java基础面试十】、何对Integer和Double类型判断相等?
|
6月前
|
安全 Java
12 Java常用类(二)(String类+时间类+BigDecimal类等等)
12 Java常用类(二)(String类+时间类+BigDecimal类等等)
51 2
|
7月前
|
Java
Java中将保留四位小数的Double转换为String的方法详解
选择合适的方法,可以使代码更加简洁、高效,同时也能满足不同场景下的需求。
152 5
|
8月前
|
Java
深入了解Java中的BigDecimal类及其方法
深入了解Java中的BigDecimal类及其方法
126 1
|
9月前
|
存储 Java
百度搜索:蓝易云【Java语言之float、double内存存储方式】
由于使用IEEE 754标准进行存储,float和double类型可以表示非常大或非常小的浮点数,并且具有一定的精度。然而,由于浮点数的特性,它们在进行精确计算时可能会存在舍入误差。在编写Java程序时,需要注意使
108 0