一、结论:
网络传输一般采用大端序,也被称之为网络字节序,或网络序。ip协议中定义大端序为网络字节序。
berkeley套接字定义了一组转换函数,用于16和32bit整数在网络序和本机字节序之间的转换。htonl,htons用于本机序转换到网络序;ntohl,ntohs用于网络序转换到本机序。
二、大端序
大端序(英:big-endian)或称大尾序。
- 数据以8bit为单位:
地址增长方向 → | |||||
... | 0x0a | 0x0b | 0x0c | 0x0d | ... |
示例中,最高位字节是0x0a 存储在最低的内存地址处。下一个字节0x0b存在后面的地址处。正类似于十六进制字节从左到右的阅读顺序。
- 数据以16bit为单位:
地址增长方向 → | |||||
... | 0x0a0b | 0x0c0d | ... |
最高的16bit单元0x0a0b存储在低位。
小端序
小端序(英:little-endian)或称小尾序。
- 数据以8bit为单位:
地址增长方向 → | |||||
... | 0x0d | 0x0c | 0x0b | 0x0a | ... |
最低位字节是0x0d 存储在最低的内存地址处。后面字节依次存在后面的地址处。
- 数据以16bit为单位:
地址增长方向 → | |||||
... | 0x0c0d | 0x0a0b | ... |
最低的16bit单元0x0c0d存储在低位。
- 更改地址的增长方向:
当更改地址的增长方向,使之由右至左时,表格更具有可阅读性。
← 地址增长方向 | |||||
... | 0x0a | 0x0b | 0x0c | 0x0d | ... |
最低有效位(lsb)是0x0d 存储在最低的内存地址处。后面字节依次存在后面的地址处。
← 地址增长方向 | |||||
... | 0x0a0b | 0x0c0d | ... |
最低的16bit单元0x0c0d存储在低位。
混合序
混合序(英:middle-endian)具有更复杂的顺序。以pdp-11为例,0x0a0b0c0d被存储为:
- 32bit在pdp-11的存储方式
地址增长方向 → | |||||
... | 0x0b | 0x0a | 0x0d | 0x0c | ... |
可以看作高16bit和低16bit以大端序存储,但16bit内部以小端存储。