当前位置:网站首页>(C语言)计算结构体大小——结构体内存对齐
(C语言)计算结构体大小——结构体内存对齐
2022-08-05 05:17:00 【Captain林】
本篇文章计划用简单的方式向大家介绍如何计算结构体大小这一问题
首先我们必须明确一件事,想要计算结构体大小,就不得不了解结构体内存对齐的规则
一、结构体的对齐规则
1.第一个成员在在与结构体变量为0的地址处
2.其他成员要对齐到某个数字(即对齐数)的整数倍地址处
对齐数 = 编译器默认对齐数与该成员对齐数中小的那一个(稍后代码展示使用的VS编译器的默认对齐数是8)
3.结构体的总大小是对齐数的倍数(每一成员都有自己的对齐数)
4.如果嵌套了结构体,结构体对齐到自己的最大对齐数的整数倍处,结构体的整体大小就是它本身(嵌套的结构体)最大对齐数的整数倍
二、规则的使用和讲解
看完上面的讲解,相信看官们都对基本规则有了基础的印象,那我们要如何理解这些规则呢?接下来我将结合实际的代码示例来讲解这个问题
下列结构体的大小如果各位看官有兴趣不妨自行在编译器中运行尝试
例1:
struct S1
{
char c1;
int i;
char c2;
};
printf("%d\n", sizeof(struct S1));
例2:
struct S2
{
char c1;
char c2;
int i;
};
printf("%d\n", sizeof(struct S2));
例3:
struct S3
{
double d;
char c;
int i;
};
printf("%d\n", sizeof(struct S3));
例4(结构体嵌套):
struct S4
{
char c1;
struct S3 s3;
double d;
};
printf("%d\n", sizeof(struct S4));

三、内存对齐存在的意义
1.平台原因
不是所有的硬件平台都能访问任意地址上的任意数据的;某些硬件平台只能在某些地址处取某些特 定类型的数据,否则抛出硬件异常。
2.性能原因
数据结构(尤其是栈)应该尽可能地在自然边界上对齐。 原因在于,为了访问未对齐的内存,处理器需要作两次内存访问;而对齐的内存访问仅需要一次访问。
总结:通过内存对齐可以用空间换时间(使计算机运算更流畅)
四、减少空间浪费和修改默认对齐数
1.如何减少空间浪费
答:将占用空间少的成员集中在一起
//例如:
struct S1
{
char c1;
int i;
char c2;
};
//可将上代码修改为如下所示
struct S2
{
char c1;
char c2;
int i;
};2.修改默认对齐数
使用#pragma预处理指令,使用方法如下
#include <stdio.h>
#pragma pack(8)//设置默认对齐数为8
struct S1
{
char c1;
int i;
char c2;
};
#pragma pack()//取消设置的默认对齐数,还原为默认结语
看到这里,相信老铁们对如何计算结构体大小已经有了基本的了解。我是计算机海洋的新进船长Captain_ldx,如果我的文章能对您有帮助的话,麻烦各位观众姥爷们点赞、收藏、关注我吧!如果你对我的文章有任何问题或者意见,欢迎在评论区给我留言。后期重点注释和知识点将持续更新......
边栏推荐
- [After a 12] No record for a whole week
- SharedPreferences和SQlite数据库
- 网络信息安全运营方法论 (下)
- 如何组织一场安全、可靠、高效的网络实战攻防演习?
- 用GAN的方法来进行图片匹配!休斯顿大学提出用于文本图像匹配的对抗表示学习,消除模态差异!
- 二、自动配置之底层注解
- Detailed explanation of BroadCast Receiver (broadcast)
- LeetCode刷题之第746题
- 【ts】typescript高阶:条件类型与infer
- It turns out that the MAE proposed by He Yuming is still a kind of data enhancement
猜你喜欢

用GAN的方法来进行图片匹配!休斯顿大学提出用于文本图像匹配的对抗表示学习,消除模态差异!

五、请求处理—Rest映射是怎样实现的?

CVPR最佳论文得主清华黄高团队提出首篇动态网络综述
![[Practice 1] Diabetes Genetic Risk Detection Challenge [IFLYTEK Open Platform]](/img/10/7aa3153e861354178f048fb73076f7.png)
[Practice 1] Diabetes Genetic Risk Detection Challenge [IFLYTEK Open Platform]

【论文精读】Rich Feature Hierarchies for Accurate Object Detection and Semantic Segmentation(R-CNN)

CVPR 2022 | 70% memory savings, 2x faster training

The University of Göttingen proposed CLIPSeg, a model that can perform three segmentation tasks at the same time

神经网络也能像人类利用外围视觉一样观察图像

LeetCode刷题之第55题

OSPF故障排除办法
随机推荐
对象比较
电子产品量产工具(5)- 页面系统实现
The University of Göttingen proposed CLIPSeg, a model that can perform three segmentation tasks at the same time
SQL(1) - Add, delete, modify and search
CH32V307 LwIP移植使用
物联网-广域网技术之NB-IoT
OSPF故障排除办法
Tensorflow steps on the pit notes and records various errors and solutions
【Promise高级用法】实现并行和串行API
《基于机器视觉的输电线路交叉点在线测量方法及技术方案》论文笔记
It turns out that the MAE proposed by He Yuming is still a kind of data enhancement
【数据库和SQL学习笔记】4.SELECT查询2:排序(ORDER BY)、聚合函数、分组查询(GROUP BY)
Tensorflow踩坑笔记,记录各种报错和解决方法
【数据库和SQL学习笔记】8.SQL中的视图(view)
【数据库和SQL学习笔记】10.(T-SQL语言)函数、存储过程、触发器
【论文阅读-表情捕捉】ExpNet: Landmark-Free, Deep, 3D Facial Expressions
LeetCode刷题之第701题
【论文精读】R-CNN 之预测框回归(Bounding box regression)问题详述
MaskDistill-不需要标注数据的语义分割
LeetCode刷题之第530题