一、 大小端概念
Big-Endian和Little-Endian的定义如下:
Little-Endian 数据的低位字节位存放在内存的低地址端,高位字节存放在内存的高地址端。Big-Endian 数据的高位字节位存放在内存的低地址端,低位字节存放在内存的高地址端。
二、 实例分析
比如十六进制数字0x12345678,它总共占4个字节(1个字节8位,2个16进制占8位,所以1个字节最大表示0xFF)。这个数据分别在大小端模式下的内存存储布局为:
大端模式
低地址 -----------------> 高地址
0x12 | 0x34 | 0x56 | 0x78
小端模式
低地址 ------------------> 高地址
0x78 | 0x56 | 0x34 | 0x12
三、 程序判断大小端
bool IsLittleEndian() {
int a = 0x1234;
char c = *(char *)&a;
if (c == 0x34) {
return true;
}
return false;
}
四、 常用系统的大小端
目前Intel的80x86系列芯片是唯一还在坚持使用小端的芯片(windows系统就是基于该架构),ARM芯片默认采用小端,但可以切换为大端。另外,对于大小端的处理也和编译器的实现有关,在C语言中,默认是小端(但在一些对于单片机的实现中却是基于大端,比如Keil 51C),Java是平台无关的,默认是大端。在网络上传输数据普遍采用的都是大端模式。