union myun
{
struct { int x; int y; int z; }u;
int k;
}a;
int main()
{
a.u.x =;
a.u.y =;
a.u.z =;
a.k = ;
printf("%d %d %d\n",a.u.x,a.u.y,a.u.z);
return ;
//输出 0,5,6
}
union类型是共享内存的,以size最大的结构作为自己的大小,这样的话,myun这个结构就包含u这个结构体,而大小也等于u这个结构体 的大小,在内存中的排列为声明的顺序x,y,z从低到高,然后赋值的时候,在内存中,就是x的位置放置4,y的位置放置5,z的位置放置6,现在对k赋 值,对k的赋值因为是union,要共享内存,所以从union的首地址开始放置,首地址开始的位置其实是x的位置,这样原来内存中x的位置就被k所赋的 值代替了,就变为0了,这个时候要进行打印,就直接看内存里就行了,x的位置也就是k的位置是0,而y,z的位置的值没有改变,所以应该是0,5,6
VS2010亲自试了下,确实如此
#include "stdafx.h"
#include <iostream>
int _tmain(int argc, _TCHAR* argv[])
{
union{
struct {
int a;int b;int c;
}a;
int k;
}b; b.a.a=;
b.a.b=;
b.a.c=;
b.k=;
int aa;
std::cout<<b.a.a<<b.a.b<<b.a.c;
std::cin>>aa;
return ;
//输出 923
}