大端字节序和小端字节序

1.什么是大小端字节序

计算机硬件有两种储存数据的方式:大端字节序(MSB)和 小端字节序(LSB)。

小端字节序(LSB)

将这样的数据存储在计算机中,地址从低位到高位应该是:78 56 34 12

int a=0x12345678

在这里插入图片描述
一共四个字节的地址,假设从0x1001 ~ 0x1004;那么,对于小端字节序来说系统是这样存储的:
在这里插入图片描述
由图可以看出,小端字节序的存储规则是:数据的低位存储在地址低位,数据的高位存储在地址高位

大端字节序(MSB)
大端字节序就是这样存储
在这里插入图片描述
由图可以看出,大端字节序的存储规则:数据的高位存储在地址的低位,数据的低位存储在地址的高位

2.验证大小端字节序

首先直接上代码

#include <stdio.h>
  
int main()
{
    int     a = 0x12345678;
    char    *p = NULL;

    p = (char *)&a;

    if(*p == 0x78)
    {
        printf("小端字节序\n");
    }

    if(*p == 0x12)
    {
        printf("大端字节序\n");
    }

    printf("p = %x\n", *p);

    return 0;
}

再来看原理:

  • 指针会指向整形变量的首地址,当我们调用*p往a的地址里面取值时,系统会根据指针类型大小取对应大小的值(char类型的指针就会从他指向的地址往里取char类型(1个字节)大小的值)
  • 当我们使用char类型的指针指向一个int类型的数,再通过 *p 取值时,只会去取其低地址位的1个字节的内容
  • 取出低地址的值,结合之前的大小端的存储规则判断得出,这是大端还是小端

运行结果
请添加图片描述

  • 7
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值