大小端存储

来源:互联网 发布:国际网页在线客服软件 编辑:程序博客网 时间:2024/05/18 08:22

今天做到一道关于存储的题,顺便回顾一下大小端:

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

0 0
原创粉丝点击