Java float型数据判断是否相等

来源:互联网 发布:秋冬季男装 知乎 编辑:程序博客网 时间:2024/06/09 23:33

Java float型数据判断是否相等

计算机表示浮点数(float或double类型)都有一个精度限制,对于超出了精度限制的浮点数,计算机会把它们的精度之外的小数部分截断。因此,本来不相等的两个浮点数在计算机中可能就变成相等的了。例如:

float a=10.222222225,b=10.222222229

数学上a和b是不相等的,但是用“==”符号比较时是相等的。

用如下的代码进行校验:

复制代码
 1 public class Test{ 2     public static void main(String[] args){ 3         isEqualOfFloat(10.222222225f, 10.222222229f); 4     } 5      6     public static void isEqualOfFloat(float a, float b){ 7         System.out.println("-------使用“==”符号比较是否相等:" + (a==b)); 8         System.out.println("-------使用“Math.abs()”方法比较是否相等:" + (Math.abs(a-b)>0) ); 9         System.out.println("-------使用“Math.abs()”方法比较是否相等(比较宽容的限制):" + (Math.abs(a-b)<0.00000001) );10         System.out.println("-------比较大小“<”:" + (a<b));11         System.out.println("-------比较大小“>”:" + (a>b));12     }13 }
复制代码

执行结果如下图:

因此一般不会直接用“==”或者“!=”对两个浮点数进行比较。判断两个浮点数是否相等可以根据他们的差的绝对值是否大于0来进行判断。

Math.abs(a-b)==0

考虑到实际应用,一般如果两个浮点数之差的绝对值小于或等于某一个可接受的误差(即精度,比如0.00000001即可),就认为它们是相等的。

Math.abs(a-b)<0.00000001
原创粉丝点击