Java 中浮点数的注意点
重要的事说三遍!
- 最好完全使用浮点数进行比较
- 最好完全使用浮点数进行比较
- 最好完全使用浮点数进行比较
先看如下实例:
float f = 0.1f;//0.1
double d = 1.0/10;//0.1
System.out.println(f==d);//false f: 0.1 d: 0.1
float d1 = 123123123131323f;
float d2 = d1+1;
System.out.println(f==d);//true
问题1:同样是 0.1 为什么会是false呢?
问题2:d1、d2 明显不一样那结果为什么是true呢?
原来float 是有限长度的、离散的、有舍入误差的、大约的、接近不等于的
所以如果我们要对浮点数进行比较时,最好完全使用浮点数进行比较
double d1 = 123123123131323f;
double d2 = d1+1;
System.out.println(d1==d2);//false
原创文章,作者:wure,如若转载,请注明出处:https://blog.ytso.com/273133.html