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

相关文章
|
3月前
|
Java
【Java】Math、System、RunTime、BigDecimal类常用方法
【Java】Math、System、RunTime、BigDecimal类常用方法
|
3月前
|
Java
【Java基础面试十一】、int和Integer有什么区别,二者在做==运算时会得到什么结果?
这篇文章解释了Java中`int`基本数据类型和其包装类`Integer`之间的区别,并指出在进行`==`运算时,`Integer`会拆箱为`int`类型,然后比较它们的值是否相等。
【Java基础面试十一】、int和Integer有什么区别,二者在做==运算时会得到什么结果?
|
3月前
|
Java
【Java基础面试十】、何对Integer和Double类型判断相等?
这篇文章讨论了如何在Java中正确比较`Integer`和`Double`类型的值,指出不能直接使用`==`操作符比较不同类型,而应该将它们转换为相同的基本数据类型(如`double`)后进行比较。
【Java基础面试十】、何对Integer和Double类型判断相等?
|
4月前
|
Java
Java中将保留四位小数的Double转换为String的方法详解
选择合适的方法,可以使代码更加简洁、高效,同时也能满足不同场景下的需求。
65 5
|
5月前
|
Java
深入了解Java中的BigDecimal类及其方法
深入了解Java中的BigDecimal类及其方法
|
5月前
|
安全 Java
java中BigDecimal详解
java中BigDecimal详解
|
6月前
|
存储 算法 Java
Java赋值运算
Java赋值运算
38 3
|
5月前
|
算法 Java
Java数据结构与算法:位运算之与、或、异或运算
Java数据结构与算法:位运算之与、或、异或运算
|
5月前
|
Java
Java的double值保留2位小数
【6月更文挑战第16天】Java的double值保留2位小数
209 0
|
6月前
|
存储 Java 数据安全/隐私保护
【Java探索之旅】运算符解密 位运算,移位运算
【Java探索之旅】运算符解密 位运算,移位运算
57 0
下一篇
无影云桌面