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; }