当前位置:首页 > 科技新闻 > 编程语言 > 正文

java double精度丢失 0.1+0.2不等于0.3
2022-05-11 10:55:59


java里,不能直接使用double进行运算

否则如下

0.1+0.2不等于0.3

//'main' method must be in a class 'Rextester'.
//Compiler version 1.8.0_111

import java.util.*;
import java.lang.*;
import java.math.*;

class Rextester
{
public static void main(String args[])
{
System.out.println("Hello, World!");
double d1 = 0.1, d2 = 0.2;
System.out.println(d1 + d2);

}
}

java double精度丢失 0.1+0.2不等于0.3_java

所以需要使用BigDecimal转一下。

BigDecimal有下列构造函数

BigDecimal(int var)  //创建一个具有参数所指定整数值的对象。
BigDecimal(double var) //创建一个具有参数所指定双精度值的对象。
BigDecimal(long var) //创建一个具有参数所指定长整数值的对象。
BigDecimal(String var) //创建一个具有参数所指定以字符串表示的数值的对象。

但是要使用BigDecimal(String var),其它的不管用!!

//'main' method must be in a class 'Rextester'.
//Compiler version 1.8.0_111

import java.util.*;
import java.lang.*;
import java.math.*;

class Rextester
{
public static void main(String args[])
{
System.out.println("Hello, World!");
double d1 = 0.1, d2 = 0.2;
System.out.println(d1 + d2);
System.out.println(new BigDecimal(d1).add(new BigDecimal(d2)).doubleValue());
System.out.println(BigDecimal.valueOf(d1).add(BigDecimal.valueOf(d2)).doubleValue());
System.out.println(new BigDecimal(Double.toString(d1)).add(new BigDecimal(Double.toString(d2))).doubleValue());
}
}

java double精度丢失 0.1+0.2不等于0.3_java_02

另附BigDecimal如何加减乘除

BigDecimal add(BigDecimal augend)  //加法运算
BigDecimal subtract(BigDecimal subtrahend) //减法运算
BigDecimal multiply(BigDecimal multiplicand) //乘法运算
BigDecimal divide(BigDecimal divisor) //除法运算

参考:

https://www.jianshu.com/p/353834bbe7da

公众哈:微程序学堂


本文摘自 :https://blog.51cto.com/s