根据 IEEE 754 ,指数位全为 1 且尾数位不全为 0 的浮点数为 NaN 。所以 NaN 应该有多种二进制形式(尾数位有多种情况),然而,我使用下面的程序进行测试,打印出来的确是 1111111110000000000000000000000 。为什么会这样?
public class Test {
public static String toBinary(String bits){
float f = Float.intBitsToFloat(Integer.parseInt(bits, 2));
int i = Float.floatToIntBits(f);
String s = Integer.toBinaryString(i);
return s;
}
public static void main(String[] args) {
System.out.println(Test.toBinary("01111111100000000000000000000001"));
}
}
一个有点怪异的问题...
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.