请选择 进入手机版 | 继续访问电脑版
我的账户
星点互联

自媒体资讯干货

亲爱的游客,欢迎!

已有账号,请

如尚未注册?

js 读取服务端发来的protobuf字节流中的float出错,须把字节流反过来读才可以

2018-7-4 11:25

查看了protobuf的源码,看到了writeFloat方法中的writeTagAndRawLittleEndian32,然后顺便了解了下LittleEndian,参考了?https://www.cnblogs.com/passingcloudss/archive/2011/05/03/2035273.htmlhttps://www.cnblo ...

查看了protobuf的源码,看到了writeFloat方法中的writeTagAndRawLittleEndian32,然后顺便了解了下LittleEndian,

参考了?https://www.cnblogs.com/passingcloudss/archive/2011/05/03/2035273.html

https://www.cnblogs.com/passingcloudss/archive/2011/05/03/2035273.html

小端格式和大端格式(Little-Endian&Big-Endian)
不同的CPU有不同的字节序类型,这些字节序是指整数在内存中保存的顺序。
最常见的有两种:
1. Little-endian:将低序字节存储在起始地址(低位编址)
2. Big-endian:将高序字节存储在起始地址(高位编址)

 
LE(little-endian):
最符合人的思维的字节序 
地址低位存储值的低位 
地址高位存储值的高位 
怎么讲是最符合人的思维的字节序,是因为从人的第一观感来说 
低位值小,就应该放在内存地址小的地方,也即内存地址低位 
反之,高位值就应该放在内存地址大的地方,也即内存地址高位 
 
BE(big-endian): 
最直观的字节序 
地址低位存储值的高位 
地址高位存储值的低位 
为什么说直观,不要考虑对应关系 
只需要把内存地址从左到右按照由低到高的顺序写出 
把值按照通常的高位到低位的顺序写出 
两者对照,一个字节一个字节的填充进去 
 
例子1:在内存中双字0x01020304(DWORD)的存储方式。 
内存地址 4000 4001 4002 4003 
   LE      04   03   02   01 
   BE      01   02   03   04 
注:每个地址存1个字节,每个字有4个字节。2位16进制数是1个字节(0xFF=11111111)。

 
例子2:如果我们将0x1234abcd写入到以0x0000开始的内存中,则结果为
    big-endian   little-endian
0x0000    0x12         0xcd
0x0001    0x23         0xab
0x0002    0xab         0x34
0x0003    0xcd         0x12

x86系列的CPU都是little-endian的字节序

原来是小端和大段的原因,刚好js也需要把字节流反过来读才行,所以把读取顺序按照小端来读就OK了



鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

这个人很懒,什么也没留下...
粉丝0 阅读111 回复0
推荐资讯
精选资讯
阅读排行
精选案例展示
关注我们
星点互联关注时代变迁

客服电话:400-234-9000

客服邮箱:vip@neoconex.com

周一至周五 9:00-18:00

公司地址:威高广场迪尚大厦海景写字楼A座1988

Powered by Discuz!X3.4@ 2017-2018 蓝盘下载 |Archiver|手机版|小黑屋|( 豫ICP备17005739号-3 )