Java float型数据判断是否相等

Java float型数据判断是否相等

计算机表示浮点数(float或double类型)都有一个精度限制,对于超出了精度限制的浮点数,计算机会把它们的精度之外的小数部分截断。因此,本来不相等的两个浮点数在计算机中可能就变成相等的了。例如:
float a=10.222222225,b=10.222222229
数学上a和b是不相等的,但是用“==”符号比较时是相等的。
用如下的代码进行校验:

public class Test{
	public static void main(String[] args){
		isEqualOfFloat(10.222222225f, 10.222222229f);
	}
   
   public static void isEqualOfFloat(float a, float b){
		System.out.println("-------使用“==”符号比较是否相等:" + (a==b));
		System.out.println("-------使用“Math.abs()”方法比较是否相等:" + (Math.abs(a-b)>0) );
		System.out.println("-------使用“Math.abs()”方法比较是否相等(比较宽容的限制):" + (Math.abs(a-b)<0.00000001) );
		System.out.println("-------比较大小“<”:" + (a<b));
		System.out.println("-------比较大小“>”:" + (a>b));
	}
}

执行结果如下图:
在这里插入图片描述
因此一般不会直接用“==”或者“!=”对两个浮点数进行比较。判断两个浮点数是否相等可以根据他们的差的绝对值是否大于0来进行判断。

Math.abs(a-b)==0

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

Math.abs(a-b)<0.00000001

猜你喜欢

转载自blog.csdn.net/pdfcxc/article/details/84797643