判断是大端还是小端

试题1:请写一个C函数,若处理器是Big_endian的,则返回0;若是Little_endian的,则返回1

解答:

int checkCPU( )

{

    {

           union w

           {  

                  int  a;

                  char b;

           } c;

           c.a = 1;

           return(c.b ==1);

    }

}

剖析:

嵌入式系统开发者应该对Little-endian和Big-endian模式非常了解。采用Little-endian模式的CPU对操作数的存放方式是从低字节到高字节,而Big-endian模式对操作数的存放方式是从高字节到低字节。例如,16bit宽的数0x1234在Little-endian模式CPU内存中的存放方式(假设从地址0x4000开始存放)为:

wKiom1ZdF8exgttoAABHmQD-zuI855.jpg

而在Big-endian模式CPU内存中的存放方式则为:

wKioL1ZdGBmT8Rz2AABFvANmrU0048.jpg

32bit宽的数0x12345678在Little-endian模式CPU内存中的存放方式(假设从地址0x4000开始存放)为:

wKioL1ZdF_yC0naVAABkBFHlHYQ868.jpg

而在Big-endian模式CPU内存中的存放方式则为:

wKioL1ZdF9vSQD_hAABfXywDfHs345.jpg

联合体union的存放顺序是所有成员都从低地址开始存放,面试者的解答利用该特性,轻松地获得了CPU对内存采用Little-endian还是Big-endian模式读写。如果谁能当场给出这个解答,那简直就是一个天才的程序员。

#include <stdio.h>

int checkCPU()
{
  union w
   {
    int a;
    char b;
   }c;

   c.a = 1;
   
  return (c.b == 1);
}
int main(int argc,char *argv[])
{
 checkCPU()?printf("little-endian\n"):printf("Big-endian\n");
 return 0;
}


你可能感兴趣的:(c,linux)