主机字节序
就是自己的主机内部,内存中数据的处理方式(不同的CPU具有不同的字节序类型),可以分为两种:
1. 大端字节序(big-endian)
按照内存的增长方向,将高序字节存储在起始地址;最直观的字节序,因为地址低位存储值的高位 ,地址高位存储值的低位。
2. 小端字节序(little-endian)
按照内存的增长方向,将低序字节存储在起始地址;最符合人的思维的字节序 , 因为地址低位存储值的低位 ,地址高位存储值的高位。
// 内存中双字 0x01020304(DWORD 4个字节) 的存储方式
4000 4001 4002 4003
LE 04 03 02 01
BE 01 02 03 04
网络字节序
是TCP/IP中规定好的一种数据表示格式,它与具体的CPU类型、操作系统等无关,从而可以保证数据在不同主机之间传输时能够被正确解释(不同体系结构的机器之间会采用不同主机字节序,所以要转换成一种约定的数序)。网络字节顺序采用大端排序方式。
linux中网络字节序与主机字节序相互转换相关函数:
htons() // 把unsigned short类型从主机序转换到网络序
htonl() // 把unsigned long类型从主机序转换到网络序
ntohs() // 把unsigned short类型从网络序转换到主机序
ntohl() // 把unsigned long类型从网络序转换到主机序