计算机中,我们知道是以字节为单位的,一个字节8位,每个地址对应一个字节,但是对于大于一个字节的数据类型,比如short(2 Byte),int( 4 Byte),另外对于
16位,32位的处理器,由于一个寄存器的宽度大于8,必然存在如何将多个字节安排问题,因此就有了大端(big endian)和小端(little endian)模式。
所谓大端模式就是将数据的高位放在低位地址,而低位放在高位地址。比如数据0x1234 ,地址0x4000 =>0x12 0x4001 =>Ox34
所谓小端模式就是将数据的低位放在低位地址,高位放在高位地址。 比如数据0x1234 ,地址0x4000 =>0x34 0x4001=>0x12
我们常用的X86结构是小端模式,而KEIL C51则为大端模式。很多的ARM,DSP都为小端模式。有些ARM处理器还可以由硬件来选择是大端模式还是小端模式。
判断CPU 模式代码如下:
union UNION_DATA { int a; int b; }; int Judge_CPU_Mode() { UNION_DATA union_data; union_data.a = 0x01; if(union_data.b == 0x01) //low address => low part value { printf("CPU: litte endian!"); return 1; } else { printf("CPU:big endian!"); return 0; } }