试题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开始存放)为:
内存地址
|
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中也是用类似的方法来判断的,在源码中可以找的到