struct和union大小计算规则

Union

一:联合类型的定义

联合也是一种特殊的自定义类型,这种类型定义的变量也包含一系列的成员,特征是这些成员公用同一块空间(所以联合也叫共用体)

比如:共用了 i 这个较大的空间

二: 联合的特点

联合的成员是共用同一块内存空间的,这样一个联合变量的大小,至少是最大成员的大小(因为联

合至少得有能力保存最大的那个成员)。

由图可知: c 和 i 的起始地址一致。

三: 联合大小的计算

联合的大小至少是最大成员的大小。

当最大成员大小不是最大对齐数的整数倍的时候,就要对齐到最大对齐数的整数倍。

比如:

重点:

联合体中有数组的时候,数组和对齐数进行比较的时候,是单个数组元素的大小和默认对齐数来进行比较得到最终的对齐数。

Un1的解释:

所以Un1中c的对齐数是1,i的对齐数是4,所以最大对齐数是4,目前联合的大小至少是最大成员的大小,也就是c数组的大小5,所以联合体最终的大小为离5最近的4的倍数,也就是8。

Un2的解释:

所以Un2中c的对齐数是2,i的对齐数是4,所以最大对齐数是4,目前联合的大小至少是最大成员的大小,也就是c数组的大小14,所以联合体最终的大小为离14最近的4的倍数,也就是16。

Struct

一. 基本原则

  1. struct中成员变量的声明顺序,与成员变量对应的内存顺序是一致的;

  2. struct本身的起始存储地址必须是成员变量中最长的数据类型的整倍数,注意是最长的数据类型,而不是最长的变量

  3. 内存对齐与编译器设置有关。

cpp 复制代码
struct {
int number;
double tmp;
};

因此结构体大小为4+4+8=16;

cpp 复制代码
struct {
int number;
double tmp;
char c;
};

因此结构体大小为4+4+8+1+7=24;结构体大小必须是最大类型长度这的整倍数,所以在尾部+7。

相关推荐
江屿风14 分钟前
C++图论基础单源最短路-常规版dijkstra算法/堆优化版dijkstra算法/bellman-ford 算法/spfa 算法流食般投喂
开发语言·c++·笔记·算法·图论
Molesidy24 分钟前
【Linux】【C++】Linux下的C++编程以及基于GDB的VSCode的C++调试
开发语言·c++
程序猿编码30 分钟前
子域猎手:一款高性能DNS枚举工具的设计与实现
linux·c++·python·c·dns
Mortalbreeze31 分钟前
C++11类的新特性:移动语义、default、delete、override详解
开发语言·c++
Frank学习路上31 分钟前
【C++】面试:面向对象与多态
c++·面试
Shadow(⊙o⊙)44 分钟前
信号1.0,信号概念、signal()处理、前后台进程、闹钟设置、初识信号三张表。
linux·运维·服务器·开发语言·c++
nazisami1 小时前
深入学习C++11
c++·c++11
(Charon)1 小时前
【C++ 面试高频:STL 容器 vector、map、unordered_map 总结】
开发语言·c++·面试
Irissgwe1 小时前
二叉树进阶
数据结构·c++·算法·c·二叉搜索树
hairenwangmiao1 小时前
c++排序(第一章----桶排序与sort排序)
数据结构·c++·排序