union 维护足够的空间来置放多个数据成员中的“一种”,而不是为每一个数据成员配置空间,在union 中所有的数据成员共用一个空间,同一时间只能储存其中一个数据成员,所有的数据成员具有相同的起始地址
#include <stdio.h>
#include <stdlib.h>
union U
{
int a;
char b[4];
};
void PrintBinary(int n)
{
/*常规计算二进制的方法,先%2,然后/2*/
int count=0;
do
{
printf("%d",n%2);
n = n/ 2;
count++;
if(count%8 == 0)
printf(" ");
}while(n!= 1);
printf("%d",n);
printf("\n");
}
void TestUnion()
{
U u;
u.a = 65535;
PrintBinary(u.a);
u.b[0]=10;
u.b[1]=255;
//u.b[1]=2;
//u.b[3]=0;
printf("%d \n",u.a);
/**
输出结果是:65290.
a原来的内存结构是:00000000 00000000 11111111 11111111
b的内存结构式: 00000000 00000000 11111111 00001010
内存结果是:00000000 00000000 11111111 00001010,即65290
注:如果b[1]=2,结果为522
union在使用的时候是共享相同的内存的,内存的内容以最近改变的值为其当前的值,如果内存中相应的位在最新改变的时候
没有被改变,则保留原值。
所以这里的int a,和char b[4]是共享同样的四个字节内存的。b的改变会导致a的值得改变,改变的大小可以按照相应位的二进制
形式去求其值。
对于b【4】也要注意其在内存中的存放形式,有本系统中存放依次是从高位到低位为b[3]b[2]b[1]b[0],每一个b代表八个字节数据。
这里涉及的是大端存储和小端存储的问题。本题里面的结果是小端存储的,intel芯片一般都是小端。
小端:较高的有效字节存放在较高的的存储器地址,较低的有效字节存放在较低的存储器地址。
大端:较高的有效字节存放在较低的存储器地址,较低的有效字节存放在较高的存储器地址。
**/
}
int main()
{
TestUnion();
system("pause");
return 0;
}