1 . 小端和大端的定义
我们知道,字节是计算机上最小的存储器寻址单位,而不是位。在几乎所有的机器上,多字节对象都被存储为连续的字节序列,对象的地址为所使用字节中最小的地址。比如有int型变量x,x的地址&x = 0x00,那么x的4个字节在存储器中的位置将是0x00,0x01,0x02和0x03。
假设x位模式为:[X31, X30, ..., X0],总共32位。定义最高有效字节(Most Significant Byte, MSB)为[X31, X30, ..., X24],最低有效字节(Least Significant Byte, LSB)为[X7, X6, ..., X0]。某些机器上x按照从LSB到MSB排列,而另外一些机器则按照从MSB到LSB排列。我们把前一种方式称作小端法(Little endian),即最低有效字节LSB在低地址;把后一种方式称作大端法(Big endian),即最高有效字节MSB在低地址。
假设x = 0x12345678,&x = 0x00。则x的字节在小端和大端机器上的内存分布如下小端 大端
------- -------
0x12 <-地址0x03-> 0x78
------- -------
0x34 0x56
------- -------
0x56 0x34
------- -------
0x78 <-地址0x00-> 0x12
------- -------
2. 小端和大端的检测方法
根据小端和大端的定义,只需比较低地址(或高地址)和预期是否一致即可。
bool IsLittleEndian() { int x = 0x12345678; char c = *(char *)&x; if (c == 0x78) return true; else return false; }
整数x在内存中的地址为0x0012FE88,内存布局情况如下:
0x0012FE84 cc cc cc cc 0x0012FE88 78 56 34 12 0x0012FE8C cc cc cc cc
可以看到低地址的值为0x78,高地址的值为0x12。
3. 网络字节顺序