zoukankan      html  css  js  c++  java
  • 如何最快测试CPU是大端机还是小端机?

    传说这是一道很经典的面试题。很多童鞋都秉承正常人的思维,老老实实写下了倒转判断的代码。谁会想到用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。看看是不是符合题意了?

    作者:pezy 出处:http://www.cnblogs.com/pezy 欢迎转载,也请保留这段声明。谢谢!
  • 相关阅读:
    polya定理
    树状数组
    离散数学通路数的矩阵计算法
    高次同余方程求解
    Uva1378
    poj2888
    poj2409&&poj1286
    poj2182
    poj2154
    判断一个字符是否为汉字
  • 原文地址:https://www.cnblogs.com/pezy/p/2257568.html
Copyright © 2011-2022 走看看