对于单一的字节(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内部以小端存储。