联合体union方式:
#include <stdio.h>
/*用共用体union来测试*/
/*这个共用体是4个字节,共用体中,a&b都是从低地址开始的*/
union my_union
{
int a;
char b;
};
int if_big_little_ending()
{
union my_union u1;
u1.a = 1;
return u1.b;
}
int main()
{
int x = if_big_little_ending();
if (1 == x)
printf("小端"); /*低位存储在低地址*/
else
printf("大端");/*低位存储在高地址,那int a中的1(低位)就是存储在高地址,那自然返回不出来1了*/
return 0;
}
运行结果:
指针方式:
#include <stdio.h>
/*用指针来测试*/
/* 指针方式其实就是共用体的本质---*/
int if_big_little_ending()
{
int a = 1;
char b = *((char *)(&a)); /* 指针方式其实就是共用体的本质---*/
return b;
}
int main()
{
int x = if_big_little_ending();
if (1 == x)
printf("小端"); /*低位存储在低地址*/
else
printf("大端"); /*低位存储在高地址,那int a中的1(低位)就是存储在高地址,那自然返回不出来1了*/
return 0;
}
来解释一下程序关键:
char b = *( (char *) (&a) )
首先,指针指向起始地址,&a的地址映射是4字节,而显式强转为了char*后,就变成char* 类型的地址,打印出来的就是那原本四个字节的第一个。再用*解引用赋值给b。如果是小端模式,1是低字节,就存储在 低地址出,自然能够打印出来1;否则,1这个低位数据存储在高地址处,char* 自然”管不到“高位地址