字节序:小端和大端

1.小端和大端(一)
小端:在最小内存地址,先存储最低有效字节。
大端:在最小内存地址,先存储最高有效字节。
实例:
一个4字节整数:s = 0x03020100;

备注:参考《Linux/UNIX系统编程手册》。

2.小端和大端(二)

小端(little-endian)字节序:低序字节存储在起始地址;
大端(big-endian)字节序:高序字节存储在起始地址。
《UNIX网络编程卷1》中有句话,非常精辟。

术语“小端”和“大端”表示多个字节值的哪一端(小端——低序字节大端——高序字节)存储在该值的起始地址。

《UNIX网络编程卷1》中有一个实例代码,结合它,我们可以更好理解小端和大端。

#include "unp.h"
int main(int argc, char **argv)
{
  union {
    short s;
    char c[sizeof(short)];
  } un;

  un.s = 0x0102;
  printf("%s: ", CPU_VENDOR_OS);
  if (sizeof(short) == 2) {
    if (un.c[0] == 1 && un.c[1] == 2)
	  printf("big-endian\n");
	else if (un.c[0] == 2 && un.c[1] == 1)
	  printf("little-endian\n");
	else
	  printf("unknown\n");
  } else
    printf("sizeof(short) = %d\n", sizeof(short));
  
  exit(0);
}

3.主机字节序和网络字节序之间的转换函数

网际协议使用大端字节序来传送这些多字节整数。套接字地址结构中的某些字段必须按照网络字节序进行维护。因此我们要关注如何在主机字节序网络字节序之间相互转换。我们使用到4个函数:

#include <netinet/in.h>

uint16_t htons(uint16_t host16bitvalue);
uint32_t htonl(uint32_t host32bitvalue);
    Both return: value in network byte order

uint16_t ntohs(uint16_t net16bitvalue);
uint32_t ntohl(uint32_t net32bitvalue);
    Both return: value in host byte order

上述函数名中:
h--host
n--network
s--short
l--long

当使用这些函数时,我们并不关心主机字节序和网络字节序的实际值(究竟是大端还是小端)。我们所要做的只是调用适当的函数在主机和网络字节序之间转换某个给定值。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值