关于大小端存储判断的问题

大端存储与小端存储区别如下:

小端存储:数据的高位数据放在高地址,低位数据放在低地址。

大端存储:大端与小端的数据存储方式相反。数据的高位数据放在低地址,低位数据放在高地址。

对于大小端存储判断的方式有两种:

方法一:字符指针判断

在32位平台下,int占4个字节,而char类型的指针是占一个字节的,如果我们把int强传为char类型的指针,只会保存一个字节的数据,那么我们只需要判断char里面的第一个字节和int里面的第一个字节是否是一致即可判断。 
如果一致则为小端模式,反之为大端模式。

注:
下面代码我们令 int a=1 如果是小端模式,int下1会存放在在低地址处,而强传为char类型的指针,1也在低地址处,所以可以判断。

#include <stdio.h>
int main()
{
    int a = 1;
    if (*(char*)&a == 1)
        printf( "小端模式" );
    else
       printf( "大端模式" );
    return 0;
}

实际测试如下:
 

方法二:联合体判断
由于联合体所有数据共享一块地址空间,存放数据的所有成员都是从低地址开始存放,所以我们可以在联合体内定义一个int和一个char类型变量,然后在外部实例化的时候创建int变量,用char变量调用,相当于隐式类型转化,如果结果为1,则低字节存放在低地址,既是小端机器,反之大端机器。

#include <stdio.h>
union Test
{
    int a;
    char b;
};
int main()
{
    Test t;
    t.a = 1;
    if (t.b == 1)
        printf( "小端模式" );
    else
        printf( "大端模式" );
    return 0;
}

实际测试如下:

发布了33 篇原创文章 · 获赞 30 · 访问量 2万+

猜你喜欢

转载自blog.csdn.net/baidu_15547923/article/details/100064256