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

相关推荐
笨笨饿4 分钟前
80_聊聊SPI以及它们的变体
linux·c语言·网络·stm32·单片机·算法·个人开发
Ricardo-Yang5 分钟前
使用GEE以及LandSat8植被指数NDVI计算
python·深度学习·神经网络·算法·视觉检测
sheeta199810 分钟前
LeetCode 每日一题笔记 日期:2026.05.12 题目:1665. 完成所有任务的最少初始能量
笔记·算法·leetcode
khalil102011 分钟前
代码随想录算法训练营Day-49 图论01 | 图论理论基础、深搜理论基础、98. 所有可达路径、广搜理论基础
c++·算法·leetcode·深度优先·图论
Chase_______21 分钟前
【算法】删除子数组的最大得分 & 最多 K 个重复元素的最长子数组——不定长滑动窗口与哈希频率约束
算法·哈希算法
fie888932 分钟前
城市环境下车辆目标跟踪算法 MATLAB 实现
算法·matlab·目标跟踪
tryCbest34 分钟前
软考 - 排序算法
算法·排序算法
AKA__Zas1 小时前
芝士算法(双指针篇 1.0)
java·算法·学习方法
吃着火锅x唱着歌1 小时前
LeetCode 726.原子的数量
linux·算法·leetcode
君义_noip1 小时前
CSP-S 2025 提高级 第一轮(初赛) 阅读程序(3)
c++·算法·信息学奥赛·csp-s 初赛