判断大端小端

大端模式(big endian)和小端模式(little endian)。


在我们发送数据的时候,我们首先要确定是大端还是小端模式来进行的,在接收方接收的数据必须知道数据是大端还是小端模式,才能正确地读取和存储数据起来,否则就会出错。

一个32位的二进制在内存中的存储时有2中分布方式:高字节对应高字节(大端模式)、高字节对应低地址(小端模式)。

有些时候CPU公司用大端(C51单片机);有些CPU用小端(ARM)。我们写代码的时候需要通过写代码来测试当前系统是打断还是小端模式

两种方法:

1.利用地址强制类型转换

void funtest1()
{
    int i = 1;
    char* j = (char*)&i;
    if (*j == 1)
    {
        printf("小端存储\n");
    }
    else
        printf("大端存储\n");
}

2.利用联合体性质:不同类型变量共享同一块内存

 

void funtest2()
{
    union UN
    {
        int i;
        char c;
    }u;
    u.i = 1;
    
    if (u.c == 1)
    {
        printf("小端存储\n");
    }
    else
        printf("大端存储\n");
}

 

注:

1)联合体的概念和特征:union维护足够的空间来存放多个数据成员中的“一种”,而不为每一个数据成员都配置空间,在union中所有的成员共用同一个空间,同一时间只存储一个数据成员,最大的特征就是所有的数据成员具有相同的起始地址即联合体的基地址。

2)计算机中字节存储主要有两种:大端模式(Big_endian)和小端模式(Little_endian),从英文名字上可以明白,大端模式是从低地址开始,高位结束;小端模式是从高地址开始,低地址结束。

3)利用union中所有数据成员具有同样的起始地址的特点,通过一个int成员存储1,然后通过char成员来读取,即可巧妙地得出数据存放的方式,若通过char成员(即读取起始位置上的第一个字节)读取,若得出值为1,则说明是小端模式。

 

参考:

https://www.cnblogs.com/linux-sir/archive/2012/07/10/2585537.html

https://blog.csdn.net/qq_35409955/article/details/73557444

 

posted @ 2018-10-09 15:26  小时候挺菜  阅读(2949)  评论(0编辑  收藏  举报