1.问题引入
看一下这段代码。
for(double x = 0;x!=10;x+=0.1)
System.out.println(x);
你是否会觉得程序最终会得到你想要的结果?很遗憾,运行后这段代码会一直循环下去,而不是停在了10的位置,想要了解问题的所在,我们就需要清楚浮点数在计算机中究竟是如何表示的。
2.早期计算机中如何表示浮点数?
类似于科学计数法,在计算机中任何一个二进制数N可以写成如下形式:
其中M为浮点数的尾数,是一个纯小数。
e为浮点数的指数,是一个整数。
那么在表示浮点数的时候需要给出确定精度的尾数,以及指明小数点位置的指数,这里习惯上称为阶码。最后还有有一个符号位来表示浮点数的符号,于是乎可以这样存储:
3.IEEE 754标准下浮点数格式
后来为了便于软件移植,统一按IEEE 754标准,将32位和6