浮点数如何在内存中表示
对于32位浮点数,最高位s是符号位,E为指数为,M为尾数(有效数字保留小数点后)
这是64位的表示
例如:11.28125用二进制表示:1011.01001 = 1.01101001 * 2^3
符号位:正数为0
指数位:127(是一个偏移) + 3(是上方2^3的指数)
尾数位:去掉小数点前的1 得到01101001(32位的尾数位为23位,有效数字放前,后面用0填充)
得到二进制数:
0 1000 0010 01101001 000000000000000
连起来:01000001001101001000000000000000
转换成16进制:0x41348000