网络传输过程的大/小端

之前我们写过c++字节序判断(大端和小端),了解了关于字节序的存放方式:大端和小端,以及大小端判断的两种方法:类型转换加解引用、联合体union的存放顺序。

Little-Endian就是低位字节排放在内存的低地址端,高位字节排放在内存的高地址端
Big-Endian就是高位字节排放在内存的低地址端,低位字节排放在内存的高地址端

今天讨论关于网络传输过程中的大小端及其转化。

一、为什么有大小端模式之分
在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为8bit。但是在除了8bit的char之外,还有16bit的short型,32bit的long型等等。另外,对于位数大于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如果将多个字节安排的问题。因此就导致了大端存储模式和小端存储模式。

二、转化原因
1、不同的电脑可能使用的端模式不一样,因此进行数据传递时必须要考虑端模式的不同。

2、在我们的网络字节传输上,TCP/IP协议规定了必须使用网络字节顺序(大端模式),而在大多数的PC机上采用的是小端模式。因此如果高于8位的数据类型要进行网络传输,我们要先将数据转换为大端再进行发送,对于接收到的数据,我们要根据自己的机器存储方式进行大小端转换后再使用。

三、如何转化
对于小于等于32位的数字来说,C语言有库进行转换,例如:

ntohl() 将一个无符号长整形数从网络字节顺序转换为主机字节顺序
htonl() 将一个32位数从主机字节顺序转换成网络字节顺序

对于大于32位的数字来说,例如64位小端转大端:

/*
 * 64位小端转大端
 */
long unsigned int hton_ll(long unsigned int data)
{
    long host_h;
    long host_l;
    long unsigned int temp;
 
    host_l = data & 0xffffffff;
    host_h = (data >> 32) & 0xffffffff;
 
    temp = htonl(host_l);
    temp = (temp << 32) | htonl(host_h);
 
    return temp;
}
  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值