《C语言深度解剖》:大端与小端

两种存储模式,概念如下
大端模式:字数据的高字节存储在低地址中,而字数据的低字节则存放在高地址中。
小端模式:字数据的高字节存储在高地址中,而字数据的低字节则存放在低地址中。
还知道有个方法选择系统是哪种存储模式及两个图:

这里写图片描述

int checkSystem()
{
    union check
    {
        int i;
        char ch;
    }c;

    c.i=1;
    return (c.ch==1);
}

然后我一直往下看,遇到这样一个题:在x86系统下,其值为多少?

int main()
{
    int a[4]={1,2,3,4};
    int *ptr1=(int*)(&a+1);
    int *ptr2=(int*)((int)a+1);

    print ("%x,%x",prt1[-1],*ptr2);

    return 0;
}

先说ptr1,我知道 &a是整个数组的首地址,所以&a+1指到了整个数组后面
这里写图片描述
因为(&a+1)这个地址转换成(int*),所以(a&+1)指向了整个数组后一个int型的整数。prt1[-1]就是 *(prt1-1),也就是a[3],所以是4,这个自己做出来了!
再看ptr2,首先我知道a表示数组首元素的首地址,(int)a+1就是把地址a转换int型加1,因为int类型是4个字节存储,(int)a+1就指向a[0]的第二个字节的指针了。转换成(int*)的ptr2就像上图表示的一样指向一个int类型, 这些我也想到了,可ptr2指向的值是多少呢?这里,就关系到存储模式的问题!
根据我的理解我可以知道a[0]为【0x00 0x00 0x00 0x01】,a[1]为 0x00 0x00 0x00 0x02,这样,可我不知道这是什么端的存储,这两天要放假也不想看,本来说放弃的,可想想以这种心态怎么可以呢?!!不是当年的我啊~,而且是一点小小的问题,不能这么看不起自己,于是就翻到前面详细看看,再解理一下,原来,静下心来问题是多么简单明了!下面是我在编辑器里做的简明示意,而且超级好记:
这里写图片描述
这样是不是很清楚呢!小端相前,大端相后。(注:有的系统是两个模式都有的。)
*ptr2的值也揭晓了,大端0x100,小端0x2000000。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值