C/C++ union

叙述原因:

union data{

int a;
double b;
};

对于union,实际中用的并不多,之前也知道怎样计算union的单元(在字对齐的基础上取最大成员所占的内存大小),比如

union data{

int a;
char b[5];
};  最大为5个字节,但为了字对齐,需要是4的倍数,sizeof(data)大小就是8,其他复杂的结构大家可以网上搜一搜,一般考的可能就是这样。

 

问题1:

union各数据单元的内存地址是否相同?

本人设想拥有最大元素的内存单元,那么各元素的地址是相同的。结果也验证了正确性。

union data{

int a;
char b;
double c;
char ch[5];
}; 

union data d;
d.a = 10;
printf("%d %d %d %d\n",&d,&d.a,&d.b,&d.c,d.ch); 4个结果全部相同。

问题2:

union data{

int a;
double b;
}; 如果设置了d.a = 10,那么d.b = ???

是不是有点蒙?如果按照 内存地址相同,说明是共享了同一块数据单元, d.b的值应该也是 10

但是 d.b != 10 。

同理如果设置了d.b = 10,那么d.a =?? 结果是d.a = 0 

但是对于特殊情况,如果data的结构是

union data{

int a;
char b;
}; 

 如果设置了d.a = 10,那么d.b =??? 其实这个时候 a.b = 10 原因是 这两个类型在C语言中的内存结构是一样的,但是 int float double却不相同。

这也就是要强调 对于结构体你用的什么赋值,就采用哪一个变量,否则值可能得不到。。

我的想法是: 他们内存的数据是一样,但是不同类型读取数据的方式不同,导致了数据与赋值数据不同。主要是数据的读取方式和对内存数据的组织方式

 

posted on 2016-04-11 09:38  日落初升  阅读(198)  评论(0编辑  收藏  举报

导航