如何最快测试CPU是大端机还是小端机?
传说这是一道很经典的面试题。很多童鞋都秉承正常人的思维,老老实实写下了倒转判断的代码。谁会想到用union呢?
union有一个特性:其存放顺序是所有成员都从低地址开始存放。
有没有一点灵感?其实什么是巧妙,就是利用融会贯通罢了。
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。看看是不是符合题意了?
传说这是一道很经典的面试题。很多童鞋都秉承正常人的思维,老老实实写下了倒转判断的代码。谁会想到用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。看看是不是符合题意了?