在存储整数时,一般按字节为逻辑单位进行存储,有“小端序”和“大端序”之分。小端序(little-endian)
是指将表示整数的低位字节存储在内存地址的低位,高位字节存储在内存地址的高位。如果将整数 1982062410 存储至内存,由于
1982062 4 10 = ( [ 00000001 ] [ 00101110 ] [ 01110000 ] [ 01010000 ] ) 2 19820624_{10}=([00000001][00101110][01110000][01010000])_2 1982062410=([00000001][00101110][01110000][01010000])2
利用 C++中的 union 数据结构(或者指针)可以很容易确定计算机使用的是何种端序。
union {
unsigned int bytes;
unsigned char lowerByte;
} block;
int main(int argc, char *argv[])
{
// 第一种方式:利用 union 的特性,将 block 的第一个成员赋值为 1,然后获取内存
// 低位字节的值。如果是小端序,低位字节存储的值为 1;若为大端序,则值为 0。
block.bytes = 1;
cout << (block.lowerByte ? "little-endian" : "big-endian") << endl;
// 第二种方式:利用指针直接获取低位字节的值。如果是小端序,低位字节存储的值为 1;
// 若为大端序,则值为 0。
unsigned int bytes = 1;
cout << (*((char *)(&bytes)) ? "little-endian" : "big-endian") << endl;
return 0;
}
强化练习:UVa594 One Little Two Little Three Little EndiansA。