网络字节序和主机字节序

 

<script type="text/javascript"></script>

 

不同的 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.

注:
1
、网络与主机字节转换函数 :htons ntohs htonl ntohl (s  就是 short l long h host n network)
2
、不同的 CPU 上运行不同的操作系统,字节序也是不同的,参见下表。
处理器      操作系统      字节排序
Alpha    
全部     Little endian
HP-PA    NT    Little endian
HP-PA    UNIX    Big endian
Intelx86    
全部     Little endian <-----x86 系统是小端字节序系统
Motorola680x()    
全部     Big endian
MIPS    NT    Little endian
MIPS    UNIX    Big endian
PowerPC    NT    Little endian
PowerPC    
NT    Big endian  <-----PPC 系统是大端字节序系统
RS/6000    UNIX    Big endian
SPARC    UNIX    Big endian
IXP1200 ARM
核心      全部     Little endian 
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值