struct 和 union 的区别

目录

1.内存布局

2.内存使用

3.用途

4.初始化和访问

5.例子


1.内存布局

  • struct :每个成员都有自己的内存空间,所有成员的内存地址是彼此独立的。struct 的大小是所有成员大小的总和,可能还包括内存对齐所需要的填充字节。
  • union :所有成员共享相同的内存空间,union 的大小等于最大成员的大小。这意味着一个时间点上,union 只能存储一个成员的值。

2.内存使用

  • struct:允许同时访问所有成员,每个成员都有自己的内存空间,因此可以同时保存多个不同的数据。
  • union:因为所有成员共用同一块内存空间,只能在某一时刻保存一个成员的数据。如果修改一个成员的值,其他成员的值也会被覆盖。

3.用途

  • struct :用于需要存储多种不同类型的数据,并且这些数据需要同时存在的情况。例如,一个人可能有名字、年龄、地址等信息,使用 struct 就很合适。
  • union :适用于节省内存的场景,特别是当多个成员不会同时使用时。例如,处理同一块数据的多种视图(如数值类型转换),可以用 union 来节省空间。

4.初始化和访问

  • struct:可以单独初始化和访问每个成员。
  • union:只能初始化和访问当前正在使用的那个成员。

5.例子

复制代码
// struct 示例
struct Person {
    char name[50];
    int age;
    double height;
};

// union 示例
union Data {
    int intValue;
    float floatValue;
    char charValue;
};

在使用 union 时需要特别小心,因为不正确的使用会导致数据混乱和不可预测的行为。struct 则更为直观和安全,适用于大多数常见的场景。

相关推荐
Justice Young8 小时前
算法分析与设计实验:贪心法求解0/1背包问题的局限性
算法
黎阳之光8 小时前
无感定位·智管全域:黎阳之光人员无感定位管理系统,重新定义安全与效率
人工智能·物联网·算法·安全·数字孪生
小许同学记录成长8 小时前
网格简化算法 — Edge Collapse(边塌缩)
qt·算法
凯瑟琳.奥古斯特8 小时前
力扣1001网格照明解法
算法·leetcode·职场和发展
fengenrong8 小时前
20260601
算法·深度优先·图论
晚笙coding8 小时前
从“看起来像双指针”到真正的动态规划 —— 最长公共子序列
算法·动态规划
05候补工程师8 小时前
【考研高数核心突破】极限的本质、高频解题套路与海涅定理深度解析(附经典例题思维导图式拆解)
经验分享·笔记·考研·算法
智者知已应修善业8 小时前
【51单片机8个LED的花样12亮34熄56间隔78闪烁3秒3闪烁】2023-11-4
c++·经验分享·笔记·算法·51单片机
老鱼说AI9 小时前
统计学习方法第五章:从浅入深解析决策树
人工智能·深度学习·算法·决策树·机器学习·学习方法
KaMeidebaby9 小时前
卡梅德生物技术快报|蛋白修饰调控 NETosis 分子机制及实验研究进展
前端·数据库·人工智能·算法·百度