字节序(大端小端)的判断和转换

77 篇文章 0 订阅
关键是big endian和little endian的概念。注意16bit机器和32bit机器(以32位为访问单位)下排列不同。
内存地址从低地址向高地址增长,big endian是高位数据优先,即高位放在低地址。而little endian是低位数据优先,低位放在低地址。网络字节序采用大端。



判断字节序:
main()
{
  int x = 0x1;

  if ((*(char *)&x) == 0x1)
     printf("little endian!\n");
  else
     printf("big endian!\n");

}

字节序转换:
ntohs(n) = __swab16(n),
ntohl = __swab32(n)。
__swab16与__swab32函数定义如下所示。

#define ___swab16(x)
{
           __u16 __x = (x);
           ((__u16)(
                       (((__u16)(__x) & (__u16)0x00ffU) << 8) |
                       (((__u16)(__x) & (__u16)0xff00U) >> 8) ));
}
#define ___swab32(x)
{
           __u32 __x = (x);
           ((__u32)(
                       (((__u32)(__x) & (__u32)0x000000ffUL) << 24) |
                       (((__u32)(__x) & (__u32)0x0000ff00UL) <<  8) |
                       (((__u32)(__x) & (__u32)0x00ff0000UL) >>  8) |
                       (((__u32)(__x) & (__u32)0xff000000UL) >> 24) ));
}

写法很严谨。简化版的:
#define swab32(x) ((x&0x000000ff) << 24 | (x&0x0000ff00) << 8 | (x&0x00ff0000) >> 8 | (x&0xff000000) >> 24)

#define swab16(x) ((x&0x00ff) << 8 | (x&0xff00) >> 8)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值