IEEE754标准是一种浮点数表示标准,一般分为
根据国际标准IEEE754,任意一个二进制浮点数V可以表示为下面形式:
其中,E为阶码位,M为尾数部分,S为符号位;
下面以32bits的浮点数为例子:
将十进制数0.15625转换为浮点数:
1. 将对应数据逐步乘以2,取整数部分;
?????????0.15625x2=0.3125 取整0?
?????????0.31250x2=0.6250 取整0
?????????0.62500x2=1.2500 取整1
?????????0.25000x2=0.5000 取整0
?????????0.50000x2=1.0000 取整1
2. 将整数部分进行组合,得到0.00101;
3. 将得到的数,表示成IEEE 754的格式,0.00101=1.01*2-3
4. 将该数据,与公式进行对比,可以得出:1.01*2**-3 = (-1)s ?* (1+M)*2**(E-127), 可以得出:
?????????s=0;
?????????1+M=1.01, M=0.01;
?????????E-127=-3, E=124; 124 = BIN 0111 1100
5. 将上述的值,填入到32bits的范围内,可得:
使用上面的方式,转换十进制数-0.0625:
?DEC -0.0625 = BIN -0.0001 = -1.0*2-4 s=1,M=1-1=0,E=-4 +127=123=0111 1011
使用上面的方式,转换十进制数127.1247:
这个数可能在32bits范围内,不能准确的表示出来,因此需要进行截位;
按照上面的公式,整数部分,127: 0111_1111;
小数部分:0.1247,不断乘以2,取整数部分,00011111111011001..., 因为位数不够,进行截断;
转换成上面的公式可以得到:M=1.11111100011111111011001,E=127+6=133, 所以转换后的浮点数为:
附上IEEE 754在线转换工具: