传说这是一道很经典的面试题。很多童鞋都秉承正常人的思维,老老实实写下了倒转判断的代码。谁会想到用union呢?
union有一个特性:其存放顺序是所有成员都从低地址开始存放。
有没有一点灵感?其实什么是巧妙,就是利用融会贯通罢了。
代码如下:
#include <iostream> using namespace std; int checkCPU(); int main() { if(checkCPU()) cout << "你的CPU是小端机." << endl; else cout << "你的CPU是大端机." << endl; return 0; } int checkCPU() { union u { int a; char b; }c; c.a = 1; return(c.b == 1); }
解释:int是32位(这里指的是常规的32位机),4byte,c.a=1,就是0x00000001,在小端机中存储方式如下:
0×0000 0×01
0×0001 0×00
0×0002 0×00
0×0003 0×00
在大端机中存储方式如下:
0×0000 0×00
0×0001 0×00
0×0002 0×00
0×0003 0×01
c.b为char型,是8位,1byte。而union又从低地址开始存放,故小端机c.b==0×01,大端机c.b==0×00。看看是不是符合题意了?