天天看点

大小端模式为什么有大小端模式之分大端和小端模式定义常见的字节序常见CPU的字节序

为什么有大小端模式之分

因为在计算机系统中,是以字节为单位的,一个地址单元对一个字节,一个字节为 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