对于单一的字节(a byte),大部分处理器以相同的顺序处理位元(bit),因此单字节的存放方法和传输方式一般相同。
对于多字节数据,如整数(32位机中一般占4字节),在不同的处理器的存放方式主要有两种,以内存中0x0A0B0C0D的存放方式为例,分别有以下几种方式:
- 注: 0x前缀代表十六进制。
Big-endian
一般称之为大端序或大尾序。
- 数据以8bit为单位:
| 地址增长方向 → | |||||
| ... | 0x0A | 0x0B | 0x0C | 0x0D | ... |
示例中,最高有效位(MSB n位二进制数字中的n-1位,即2进制数的左面第一位)是0x0A 存储在最低的内存地址处(图中的a)。下一个字节0x0B存在后面的地址处。正类似于十六进制字节从左到右的阅读顺序 (正序)。
- 数据以16bit为单位:
| 地址增长方向 → | |||||
| ... | 0x0A0B | 0x0C0D | ... | ||
最高的16bit单元0x0A0B存储在低位。
Little-endian
一般称之为小端序或小尾序。
- 数据以8bit为单位:
| 地址增长方向 → | |||||
| ... | 0x0D | 0x0C | 0x0B | 0x0A | ... |
最低有效位(LSB 即2进制数的最后第一位, 左往右顺序)是0x0D 存储在最低的内存地址处。后面字节依次存在后面的地址处。(倒序)
- 数据以16bit为单位:
| 地址增长方向 → | |||||
| ... | 0x0C0D | 0x0A0B | ... | ||
最低的16bit单元0x0C0D存储在低位。
- 更改地址的增长方向:
当更改地址的增长方向,使之由右至左时,表格更具有可阅读性。
| ← 地址增长方向 | |||||
| ... | 0x0A | 0x0B | 0x0C | 0x0D | ... |
最低有效位(LSB)是0x0D 存储在最低的内存地址处。后面字节依次存在后面的地址处。
| ← 地址增长方向 | |||||
| ... | 0x0A0B | 0x0C0D | ... | ||
最低的16bit单元0x0C0D存储在低位。
Middle-endian
middle-endian具有更复杂的顺序,也可称为混合序,以PDP-11为例,0x0A0B0C0D被存储为:
- 32bit在PDP-11的存储方式
| 地址增长方向 → | |||||
| ... | 0x0B | 0x0A | 0x0D | 0x0C | ... |
可以看作最高的16bit位和低位以大端序存储,但16bit内部以小端存储。
本文详细介绍了计算机系统中不同字节序的存储方式,包括大端序(Big-endian)、小端序(Little-endian)及混合序(Middle-endian)。通过具体实例说明了这些字节序如何处理多字节数据,帮助读者理解数据在内存中的存储形式。
1280

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



