联合(union)在C里面见得并不多,但是在一些对内存要求特别严格的地方,联合又是频繁出现,那么究竟什么是联合?怎么去用?有什么需要注意的地方呢?
(1)什么是联合?一种构造类型的数据结构。在一个“联合”内可以定义多种不同的数据类型, 一个被说明为该“联合”类型的变量中,允许装入该“联合”所定义的任何一种数据,这些数据共享同一段内存,已达到节省空间的目的。这是一个特殊的地方,也是联合的特征。
(2)联合与结构的区别?“联合”与“结构”有一些相似之处,但两者有本质上的不同。在结构中各成员有各自的内存空间, 一个结构变量的总长度是各成员长度之和(空结构除外,同时不考虑边界调整)。而在“联合”中,各成员共享一段内存空间, 一个联合变量的长度等于各成员中最长的长度。应该说明的是, 这里所谓的共享不是指把多个成员同时装入一个联合变量内, 而是指该联合变量可被赋予任一成员值,但每次只能赋一种值, 赋入新值则冲去旧值。下面举一个例了来加对深联合的理解。
int _tmain(int argc, _TCHAR* argv[])
{
union number
{
int i;
struct
{
char first;
char second; //由最右边开始排,即second first
}half;
}num;
num.i=0x4241;
printf("%c %c /n",num.half.first,num.half.second);
num.half.first='a';
num.half.second='b';
printf("%x /n",num.i);
getchar();
}
输出结果为: AB 6261
(3)如何说明?联合变量的说明有三种形式:先定义再说明、定义同时说明和直接说明。以test类型为例,说明如下:
1) union test
{
int office;
char teacher[5];
};
union test a,b; /*说明a,b为test类型*/
2) union test
{
int office;
char teacher[5];
} a,b;
3) union
{
int office;
char teacher[5];
} a,b;
经说明后的a,b变量均为test类型。a,b变量的长度应等于test的成员中最长的长度,即等于teacher数组的长度,共5个字节。a,b变量如赋予整型值时,只使用了4个字节,而赋予字符数组时,可用5个字节。
(4)需要讨论的地方。联合里面那些东西不能存放?我们知道,联合里面的东西共享内存,所以静态、引用都不能用,因为他们不可能共享内存。
(5)关于联合类型的子数据没有具体大小的现象。
typedef union DAY_REGISTER
{
UINT32 value;
struct
{
unsigned seconds : 6;
unsigned minutes : 6;
unsigned hours : 5;
unsigned dayOfWeek : 3;
unsigned weekOfMonth: 3;
unsigned reserved : 9; //注意以上这些定义没有具体类似INT的类型符号
};
} DayRegister;
DayRegister dayReg;
typedef struct _SYSTEMTIME {
WORD wDayOfWeek;
WORD wHour;
WORD wMinute;
WORD wSecond;
WORD wMilliseconds;
} SYSTEMTIME, *LPSYSTEMTIME;
LPSYSTEMTIME pTime;
结果,以下的赋值操作是有效的:
dayReg.dayOfWeek = pTime->wDayOfWeek + 1;
dayReg.hours = pTime->wHour;
dayReg.minutes = pTime->wMinute;
dayReg.seconds = pTime->wSecond;