2021-11-04 Union的用法总结

定义:

union是一种类似与struct的联合体,叫做共同体。他的定义格式是:
union 共同体名{
成员列表
};

特点:

结构体和共同体的区别在于:

  1. 结构体的各个成员会占用不同的内存,相互之间没有影响;而共同体的所有成员占用同一段内存,修改一个成员会影响其余所有成员。
  2. 结构体占用的内存大于等于所有成员占用的内存的之和。(成员之间可能会存在缝隙)。
  3. 共同体占用的内存等于最长的成员占用的内存
  4. 共同体使用了内存覆盖技术,同一时刻只能保存一个成员的值,如果对新的成员复制,就会把原来成员的值覆盖掉。

代码块:

union{
    int n;
    char ch;
    double f;
} a, b, c;

在共同体中,成员f占用的内存最多,为8个字节。所以这个共同体(a,b,c)也占用8个字节的内存。

运行代码:

#include <stdio.h>
union data{
    int n;
    char ch;
    short m;
};
int main(){
    union data a;
    printf("%d, %d\n", sizeof(a), sizeof(union data) );
    a.n = 0x40;
    printf("%X, %c, %hX\n", a.n, a.ch, a.m);
    a.ch = '9';
    printf("%X, %c, %hX\n", a.n, a.ch, a.m);
    a.m = 0x2059;
    printf("%X, %c, %hX\n", a.n, a.ch, a.m);
    a.n = 0x3E25AD54;
    printf("%X, %c, %hX\n", a.n, a.ch, a.m);
   
    return 0;
}

运行结果:

4, 4
40, @, 40
39, 9, 39
2059, Y, 2059
3E25AD54, T, AD54

结论:

想要理解上面的输出的结果。就需要理解成员在内存之间的分布,以上面的data为例。各个成员在内存中的分布如下所示:

union共同体的成员的内存分布图
成员之间在内存中:都会对齐到一头,对于ch来说,它占用的是第一个字节;对于m来说,它占用的是前两个字节,n就是前四个字节。
也就是说,修改ch的时候,会影响m和n的前一个字节。如果修改n的字节,那么对于ch和m来说就是修改全部的内存。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值