问题描述
RT,这种结构最后一次赋值会把之前的赋值覆盖掉,所以很好奇请问一下这种东西一般应用在什么场景呢?
问题解答
回答1:省内存,方便取高低字节
回答2:最初目的就是为了节省内存,你想当初C语言在上个世纪八十年代才开始大规模使用,那时的内存很宝贵的。
回答3:可以提供对同一段数据不同的访问接口。。。举个例子,曾经做嵌入式的时候,可以这样写:
// 没有字节对齐,或者字节对齐为1,int 占4字节typedef union { unsigined int num; struct {unsigned char byte0;unsigned char byte1;unsigned char byte2;unsigned char byte3; } bytes;} Demo;
不过这样写也不太简洁,而且这段代码在 PC 里面和直接通过位移取每一个字节效率是一样的。只是举个例子,不要太纠结。
回答4:一般用来判断大小端
回答5:在嵌入式开发中用的比较多,我这里给个例子,和上面 @zonxin 的差不多
typedef struct __regular_descriptor_4_high { union {U32 value;struct { U32 raid_id0 : 4; U32 raid_cmd0 : 4; U32 raid_id1 : 4; U32 raid_cmd1 : 4; U32 raid_id2 : 4; U32 raid_cmd2 : 4; U32 raid_id3 : 4; U32 raid_cmd3 : 4;} reg_des_bit; } u; } reg_des_4_high;
要读取整个寄存器可以读value,要写不同的bit-filed就用reg_des_bit来写。