很多人都知道float是浮点类型,它不能表示数据范围内的所有数值。但是,实际使用或编码时,你又是否记得这句话呢?下面是stackoverflow中的一个问题:
why does a float variable stop incrementing at 16777216
下面是待执行的代码:
float a = 0; while (true) { a++; if (a > 16777216) break; // Will never break... a stops at 16777216 }
导致上面break不会跳出的原因就是:a是加不到16777217的,因为float真的无法表示16777217。
16777216就是224,按照下面的方式来表示32个bit位
下面这张图显示了16777216的二进制表示
现在,让我们看看float是如何表示16777217(224+1)的。
float能表示的下一个数值是16777218=1*224*(1+2-23)=224+2
https://docs.oracle.com/cd/E19957-01/806-3568/ncg_goldberg.html
http://floating-point-gui.de/basic/
原文:http://www.cnblogs.com/songqiang/p/what-you-should-know-about-float.html