C中的union和struct的区别,为什么要发明union?
union和struct的区别在于:
1、对于一个union类型的变量,所有成员变量共享一块内存,该内存的大小有这些成员变量中长度最大的一个来决定
2、union分配的内存是连续的,这一点非常重要。
更具体的看这里,还有测试代码呢(附件1):
那为什么要发明union呢?这是由于union的特性决定的,特别是上述的第二点,因为struct中成员变量虽然内存都是独立的,但是struct不能保证分配的内存是连续的。
举个例子:CPU的ax寄存器分为ah和al两部分,我们现在要给其赋值,就可以采用union:
1、对于一个union类型的变量,所有成员变量共享一块内存,该内存的大小有这些成员变量中长度最大的一个来决定
2、union分配的内存是连续的,这一点非常重要。
更具体的看这里,还有测试代码呢(附件1):
那为什么要发明union呢?这是由于union的特性决定的,特别是上述的第二点,因为struct中成员变量虽然内存都是独立的,但是struct不能保证分配的内存是连续的。
举个例子:CPU的ax寄存器分为ah和al两部分,我们现在要给其赋值,就可以采用union:
union _ax_register {
int i; // 4Bytes, union将按此分配一个4字节的连续内存
unsigned short ah; // 2 Bytes
unsigned short al; // 2 Bytes
} ax_register;
现在,给ax_register.i赋值,其高16bit就会赋给ah,低16bit就会赋给al,是不是很方便呢?
再举个例子,IP地址,我们使用union,就可以直接给他赋一个int值,就能给IPunion是什么类型的四个段同时赋值,如果用struct,就麻烦多喽,如下:
int i; // 4Bytes, union将按此分配一个4字节的连续内存
unsigned short ah; // 2 Bytes
unsigned short al; // 2 Bytes
} ax_register;
现在,给ax_register.i赋值,其高16bit就会赋给ah,低16bit就会赋给al,是不是很方便呢?
再举个例子,IP地址,我们使用union,就可以直接给他赋一个int值,就能给IPunion是什么类型的四个段同时赋值,如果用struct,就麻烦多喽,如下:
union _ip_address {
int i; // spaceholder
unsigned char ip_first_num;
unsigned char ip_second_num;
unsigned char ip_third_num;
unsigned char ip_fourth_num;
} ip_address;
这样,给ip_address.i 赋值,就自动将其8bit 8bit的赋给了四个IP字段。是不是很方便?更方便的是,现在要比较两个IP地址的大小,只要比较这个int值就OK了。
int i; // spaceholder
unsigned char ip_first_num;
unsigned char ip_second_num;
unsigned char ip_third_num;
unsigned char ip_fourth_num;
} ip_address;
这样,给ip_address.i 赋值,就自动将其8bit 8bit的赋给了四个IP字段。是不是很方便?更方便的是,现在要比较两个IP地址的大小,只要比较这个int值就OK了。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论