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 欢迎转载,也请保留这段声明。谢谢!
  • 相关阅读:
    [考试]20150811
    [考试]20150810
    [随笔]暑假过了,暑假来了
    [考试]20150808
    动态规划大合集II
    [知识点][旧版]C++中的运算符
    NOIP动态规划大合集
    [考试]20150729
    [考试]20150728
    /=============分隔线=============/
  • 原文地址:https://www.cnblogs.com/pezy/p/2257568.html
Copyright © 2011-2022 走看看