大小端模式

为什么有大小端模式之分

因为在计算机系统中,是以字节为单位的,一个地址单元对一个字节,一个字节为 8bit。但是在C语言中除了8bit的char之外,还有16bit的short型,32bit的long型(要看具体的编译器)。另外,对于位数大于 8位的处理器,例如16位或者32位处理器,寄存器宽度大于一个字节,那么必然存在着一个如何将多个字节安排存储的问题。因此就导致了大端存储模式和小端存储模式。

大端和小端模式定义

多个字节值的哪一端存储在该值的起始地址。

1) Little-Endian就是低位字节值放在内存的低地址端,高位字节值放在内存的高地址端。

2) Big-Endian就是高位字节值放在内存的低地址端,低位字节值放在内存的高地址端。

举一个例子,比如32位int类型变量n的值为0x12 34 56 78在内存中的表示形式为:

1)大端模式:
内存地址:  低地址 -----------------> 高地址
n的字节序:0x12  |  0x34  |  0x56  |  0x78
2)小端模式:
内存地址:  低地址 ------------------> 高地址
n的字节序:0x78  |  0x56  |  0x34  |  0x12
可见,大端模式和字符串的存储模式类似。

常见的字节序

一般操作系统都是小端,而通讯协议是大端的。

例如进行网络数据传递时,要考虑端模式的转换。在Socket接口编程中,以下几个函数用于大小端字节序的转换。

[cpp] view plaincopy
  1. #define ntohs(n)     //16位数据类型网络字节顺序到主机字节顺序的转换  
  1. #define htons(n)     //16位数据类型主机字节顺序到网络字节顺序的转换  
  1. #define ntohl(n)      //32位数据类型网络字节顺序到主机字节顺序的转换  
  1. #define htonl(n)      //32位数据类型主机字节顺序到网络字节顺序的转换  

常见CPU的字节序

Little Endian : x86、DEC
Big Endian : PowerPC、IBM、Sun
ARM既可以工作在大端模式,也可以工作在小端模式。

详情参考:http://blog.csdn.net/ce123/article/details/6971544

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值