大小端存储问题

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

  1. int checkCPU() 
  2.  { 
  3.   union w 
  4.   {   
  5.    int  a; 
  6.    char b; 
  7.   } c; 
  8.   c.a = 1; 
  9.   return (c.b == 1); 
  10.  } 
剖析:
嵌入式系统开发者应该对Little-endian和Big-endian模式非常了解。采用Little- endian模式的CPU对操作数的存放方式是从低字节到高字节,而Big-endian模式对操作数的存放方式是从高字节到低字节。例如,16bit宽的数0x1234在Little-endian模式CPU内存中的存放方式(假设从地址0x4000开始存放)为:
内存地址
0x4000
0x4001
存放内容
0x34
0x12
而在 Big-endian 模式 CPU 内存中的存放方式则为:
内存地址
0x4000
0x4001
存放内容
0x12
0x34
32bit 宽的数 0x12345678 Little-endian 模式 CPU 内存中的存放方式(假设从地址 0x4000 开始存放)为:
内存地址
0x4000
0x4001
0x4002
0x4003
存放内容
0x78
0x56
0x34
0x12
而在 Big-endian 模式 CPU 内存中的存放方式则为:
内存地址
0x4000
0x4001
0x4002
0x4003
存放内容
0x12
0x34
0x56
0x78
联合体 union 的存放顺序是所有成员都从低地址开始存放,面试者的解答利用该特性,轻松地获得了 CPU 对内存采用 Little-endian 还是 Big-endian 模式读写。如果谁能当场给出这个解答,那简直就是一个天才的程序员。

在linux中也是用类似的方法来判断的,在源码中可以找的到

你可能感兴趣的:(c,linux,面试,嵌入式,存储)