在网上并没有任何信息或则资料介绍关于浮点数的大小端转换的原理的问题,大小端是不同的内存存储实现方式,大端更符合人的阅读习惯,而小端则是更适合CPU读取。
我先说整型,来说明大小端在内存中的存储方式,整型数据在内存中就是符号和数据两个部分,而且符号占一位,用32位整数举例,大端方式在内存中排列的顺序如下:
[0...7] [8...15] [16...23] [24...31]
0是标志位,1-31是数据。地址由小向大增加,而数据从高位往低位放,我们用 999 来说明,内存中存放的数据是:00 00 03 E7
而小端方式呢,则在内存中如下存储:
[24...31] [16...23] [8...15] [0...7]
地址由小向大增加,而数据从低位往高位放,同样用 999 来说明,内存中存放的数据是:E7 03 00 00
而浮点数则比整型复杂一些。按照ieee的浮点数格式,32位浮点型的格式如下,这个也是大端的存储方式:
B0 B1 B2 B3
[SEEEEEEE] [EDDDDDDD] [DDDDDDDD] [DDDDDDDD]
S表示符号,E表示指数,D表示分数。

本文详细介绍了整型及浮点型数据在不同字节序(大小端)下的内存存储方式,通过具体实例解析了IEEE浮点数格式及其转换方法。
最低0.47元/天 解锁文章
1364

被折叠的 条评论
为什么被折叠?



