大小端详解

这里写图片描述
从上边我们可以看出a、b在计算机中存储的是补码,但是顺序却倒着的,这实际上就是小端存储

1.大小端定义

大端存储模式:是指数据的低位字节序保存在内存的高地址中,而数据的高位字节序保存在内存的低地址中
小端存储模式:是指数据的低位字节序保存在内存的低地址中,而数据的高位字节序保存在内存的高地址中

例如:变量x在内存中的地址为0x0010,x的值为0x1122,那么0x11为高位字节序,而0x22为低位字节序。对于大端存储,将0x11放在低地址中,既0x0010,0x22则放在高地址中,既0x0011。小端模式刚好相反。

2.为什么会有大小端之分

在计算机系统中,是以字节为单位的,每个地址单元都对应着一个字节,一个字节为8bit。但是在C语言中除了8bit的char之外,还有16bit的short型,32bit的long型(要看具体的编译器),另外,对于位数大于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如果将多个字节安排的问题。因此就导致了大端存储模式和小端存储模式。我们常用的X86结构是小端模式,
而KEIL C51则为大端模式。很多的ARM,DSP都为小端模式。有些ARM处理器还可以由硬件来选择是大端模式还是小端模式。

ps:注意 51单片机是大端存储,STM32默认是小端存储,X86下的Windows是小端.

3.怎么设计一个程序来判断当前机器是大端存储还是小端存储
①方法一
算法思路:
这里写图片描述

参考代码:

#include<stdio.h>

int check_sys()
{
    int i = 1;
    return (*((char*)&i));
    //返回1表示小端
    //返回0表示大端
}
int main()
{
    int ret = check_sys();
    if (1 == ret)
    {
        printf("小端\n");
    }
    else
    {
        printf("小端\n");
    }
    system("pause");
    return 0;
}

②方法二
算法思路:定义一个联合体,根据联合体成员起始地址相同巧妙的访问到了第一个字节地址的数据。
联合体类型特点:
这里写图片描述

参考代码:

#include<stdio.h>

int check_sys()
{
    union
    {
        int i;
        char c;
    }un;
    un.i = 1;
    return un.c;
    //返回1表示小端
    //返回0表示大端
}
int main()
{
    int ret = check_sys();
    if (1 == ret)
    {
        printf("小端\n");
    }
    else
    {
        printf("小端\n");
    }
    system("pause");
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值