为什么有大小端模式之分
因为在计算机系统中,是以字节为单位的,一个地址单元对一个字节,一个字节为 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- #define ntohs(n) //16位数据类型网络字节顺序到主机字节顺序的转换
- #define htons(n) //16位数据类型主机字节顺序到网络字节顺序的转换
- #define ntohl(n) //32位数据类型网络字节顺序到主机字节顺序的转换
- #define htonl(n) //32位数据类型主机字节顺序到网络字节顺序的转换
常见CPU的字节序
Little Endian : x86、DEC
Big Endian : PowerPC、IBM、Sun
ARM既可以工作在大端模式,也可以工作在小端模式。