网络字节序和主机字节序

不同的 CPU 有不同的字节序类型 这些字节序是指整数在内存中保存的顺序 这个叫做主机序
最常见的有两种

1
Little endian :将低序字节存储在起始地
2
Big endian :将高序字节存储在起始地

LE little-endian
最符合人的思维的字节序
地址低位存储值的低位

地址高位存储值的高位

怎么讲是最符合人的思维的字节序,是因为从人的第一观感来说

低位值小,就应该放在内存地址小的地方,也即内存地址低位

反之,高位值就应该放在内存地址大的地方,也即内存地址高位


BE big-endian
最直观的字节序

地址低位存储值的高位

地址高位存储值的低位

为什么说直观,不要考虑对应关系

只需要把内存地址从左到右按照由低到高的顺序写出

把值按照通常的高位到低位的顺序写出

两者对照,一个字节一个字节的填充进去


例子:在内存中双字 0x01020304(DWORD) 的存储方


内存地址

4000 4001 4002 4003
LE 04 03 02 01
BE 01 02 03 04

例子:如果我们将 0x1234abcd 写入到以 0x0000 开始的内存中,则结果 

       big-endian   little-endian
0x0000   0x12       0xcd
0x0001   0x23       0xab
0x0002   0xab       0x34
0x0003   0xcd       0x12
x86
系列 CPU 都是 little-endian 的字节序 .

网络字节顺序是 TCP/IP 中规定好的一种数据表示格式,它与具体的 CPU 类型、操作系统等无关,从而可以保证数据在不同主机之间传输时能够被正确解释。网络字节顺序采用 big endian 排序方式。


为了进行转换 bsd socket 提供了转换的函数 有下面四个
htons
unsigned short 类型从主机序转换到网络序
htonl
unsigned long 类型从主机序转换到网络序
ntohs
unsigned short 类型从网络序转换到主机序
ntohl
unsigned long 类型从网络序转换到主机

在使用 little endian 的系统中 这些函数会把字节序进行转
在使用 big endian 类型的系统中 这些函数会定义成空


同样 在网络程序开发时 或是跨平台开发时 也应该注意保证只用一种字节序 不然两方的解释不一样就会产生 bug.

你可能感兴趣的:(网络)