今天做到一道关于存储的题,顺便回顾一下大小端:
union X
{
int32_t a;
struct
{
int16_t b;
int16_t c;
};
};
int main(){
X x;
x.a=0x20150810;
printf("%x,%x\n",x.b,x.c);
return 0;
}
问输出是什么?
大家肯定都知道了这一道题要从大小端存储出发考虑
首先具体介绍一下大小端的存储模式
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
如果是小端存储:0x20150810在内存中的存储形式为 10 08 15 20
所以输出 printf(“%x,%x\n”,x.b,x.c)时为08 10 20 15
如果是打断存储:0x20150810在内存中的存储形式为 20 15 08 10
所以输出 printf(“%x,%x\n”,x.b,x.c)时为20 15 08 10