Union内存分布

最近研究union,发现union内存分布挺有意思。

Union定义是什么?

Union是中文名是联合体,类似于struct,但是跟struct有很多区别,里面参数公用内存。

Union和struct的区别

①结构体(struct)中所有变量是"共存"的------优点是"有容乃大",全面;缺点是struct内存空间的分配是粗放的,不管用不用,全分配。

②而联合体(union)中是各变量是"互斥"的------缺点就是不够"包容";但优点是内存使用更为精细灵活,也节省了内存空间。

下面我们通过例子看看Union内存分布。

复制代码
#include <stdio.h>
int main(){
    typedef union {
       long i;
       int k[4];
       char c;    
    }DATE;
    struct data
    {
        int cat;
        DATE cow;
        double dog;
    }too;
    DATE max;
    long a = 0;
    printf("%ld , %ld ,%ld\r\n",sizeof(struct data),sizeof(max),sizeof(struct data)+sizeof(max));
    printf("%p,%p ,%p\r\n", &max.i,&max.k,&max.c);
    printf("%ld\r\n",sizeof(long));
    return 0;
    
}

上面代码运行结果是

复制代码
32 , 16 ,48
0x7ffc73484f50,0x7ffc73484f50 ,0x7ffc73484f50
8

看到第二行,访问Union变量里面的参数,地址都是一样的,完全就是共用一个内存首地址,并且各种变量名都可以同时使用,操作也是共同生效

内存分配

根据上面代码,union分配内存大小是16,因为long i 内存分配大小是8,int k4大小是16,char c分配大小是1,说明union分配大小是根据最大参数内存大小分配。

但是如果把int k4改成k5呢,上面结果会出现什么?

复制代码
#include <stdio.h>
int main(){
    typedef union {
       long i;
       int k[5];
       char c;    
    }DATE;
    struct data
    {
        int cat;
        DATE cow;
        double dog;
    }too;
    DATE max;
    long a = 0;
    printf("%ld , %ld ,%ld\r\n",sizeof(struct data),sizeof(max),sizeof(struct data)+sizeof(max));
    printf("%p,%p ,%p\r\n", &max.i,&max.k,&max.c);
    printf("%ld\r\n",sizeof(long));
    return 0;
    
}

运行结果是

复制代码
40 , 24 ,64
0x7fffbde34f10,0x7fffbde34f10 ,0x7fffbde34f10
8

此时union分配内存大小是24,前面不是说好了union分配大小是根据最大参数内存大小分配吗?

下面还有个概念,就是内存对齐,因为在64位机器上,long站8个字节,int k5占用20个字节,

但是由于内存对齐的原因,系统会将联合体的大小调整为最大成员大小的整数倍,即24个字节(20不是8的整数倍,所以会向上取整到24个字节)。

相关推荐
Billlly几秒前
莫比乌斯反演学习笔记
算法
stolentime1 小时前
CF2066D1 Club of Young Aircraft Builders (easy version)题解
c++·算法·动态规划·组合数学
Dillon Dong1 小时前
【风电控制】高低穿现场失败的原因分析——算法简单但工程复杂
算法·变流器·风电控制·dfig
小欣加油1 小时前
leetcode41 缺失的第一个正数
数据结构·c++·算法·leetcode
I Promise341 小时前
智驾APA_HPA可行驶区域检测算法工程师面试问题整理可参考
算法·面试·职场和发展
智者知已应修善业1 小时前
【51单片机按键控制1分钟正计时倒计时暂停复位】2024-1-2
c++·经验分享·笔记·算法·51单片机
weixin_468466851 小时前
UNet 模型结构从零搭建与实战解析
人工智能·深度学习·算法·机器学习·ai·unet
Useasy_JIJIANYUN2 小时前
合作快讯:极简云呼叫中心(Useasy)正式上架Zoho全球应用市场!
算法
isyoungboy2 小时前
Delaunay 拓扑图割法一种特征抽稀算法
算法
Shan12052 小时前
算法案例精讲:连接所有点的最小费用
算法