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 则更为直观和安全,适用于大多数常见的场景。

相关推荐
mount_myj2 小时前
敏感信息屏蔽(一)【java】
java·算法·极课堂
先做个垃圾出来………3 小时前
偏移量解释
数据结构·算法
FanXing_zl3 小时前
基于整数MCU的FOC控制定标策略深度解析
单片机·嵌入式硬件·mcu·算法·定点运算·q15
立志成为大牛的小牛3 小时前
数据结构——三十三、Dijkstra算法(王道408)
数据结构·笔记·学习·考研·算法·图论
地平线开发者4 小时前
mul 与 reduce_sum 的优化实例
算法·自动驾驶
坚持编程的菜鸟4 小时前
LeetCode每日一题——Pow(x, n)
c语言·算法·leetcode
csdn_aspnet5 小时前
分享MATLAB在数据分析与科学计算中的高效算法案例
算法·matlab·数据分析
白云千载尽5 小时前
moveit使用和机器人模型与状态--正向运动学和逆向运动学分析(四)
算法·机器人·逆运动学·moveit·正向运动学
我想吃余5 小时前
【0基础学算法】前缀和刷题日志(三):连续数组、矩阵区域和
算法·矩阵·哈希算法
2501_938773995 小时前
文档搜索引擎搜索模块迭代:从基础检索到智能语义匹配升级
人工智能·算法·搜索引擎