在java中浮点数通常是不精确的,在判断大小时
public class Test {
public static void main(String[] args) {
double X = 1.0 / 10;
double Y = 1 - 9.0 / 10;
if (X == Y) {
System.out.println("相等");
} else {
System.out.println(X+"------"+Y);
}
}
}
运行结果是不相等
![]()
so 比较浮点数大小:
// 比较x和y是否相等,先计算其差的绝对值:
double Z = Math.abs(X - Y);
// 再判断绝对值是否足够小:
if (Z < 0.00001) {
// 相等
} else {
// 不相等
}
本文探讨了Java中浮点数的精度问题,通过实例演示了直接比较浮点数可能导致的错误结果,并提供了正确的比较方法,即通过计算两数差的绝对值并判断其是否小于一个足够小的阈值。

416

被折叠的 条评论
为什么被折叠?



