float转换为二进制

来源:互联网 发布:阿里云 共享存储 编辑:程序博客网 时间:2024/05/22 12:24

float在计算机中占32-bit,从左到右为:符号位(1-bit)、指数位(8-bit)、底数位(23-bit)。

说明:符号位:负1,正0

            指数位:在得到指数后,+127

            底数位:移动小数点到只剩1位整数,小数点左侧换为二进制,小数点右侧从左到右位的权重分别为:1/2、1/4、1/8...换算完后,省略掉第一个数字1

            最后,按次序拼接起来就是该float数值的二进制表示形式

float b = 0;   // 底数以及指数都为0

PS:以上是针对正数的,负数部分在以后碰到后会加以补充的。

          尚不知指数位为什么要加127.

1 0