网络字节序和主机字节序

本文介绍了主机字节序中的大端和小端概念,解释了它们在内存中的存储方式,并通过示例说明了双字在不同字节序下的表示。同时,讨论了网络字节序作为跨平台通信的标准,其采用大端字节序。在Linux中,使用htons(), htonl(), ntohs()以及ntohl()进行字节序转换。了解这些基础知识对于网络编程至关重要。
摘要由CSDN通过智能技术生成

 

 

主机字节序

就是自己的主机内部,内存中数据的处理方式(不同的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类型从网络序转换到主机序

 

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值