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

    传说这是一道很经典的面试题。很多童鞋都秉承正常人的思维,老老实实写下了倒转判断的代码。谁会想到用union呢?

    union有一个特性:其存放顺序是所有成员都从低地址开始存放

    有没有一点灵感?其实什么是巧妙,就是利用融会贯通罢了。

    代码如下:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    #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

  • 相关阅读:
    查找最大回文
    java-线程池
    Java基础 IO流——第一部分
    tomcat优化
    反射
    网络编程——第二部分
    网络编程——第一部分
    Java基础 IO流——第四部分
    Java基础 IO流——第三部分
    Java基础 IO流——第二部分
  • 原文地址:https://www.cnblogs.com/rosesmall/p/2419527.html
Copyright © 2011-2022 走看看