当前位置:网站首页>(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,如果我的文章能对您有帮助的话,麻烦各位观众姥爷们点赞、收藏、关注我吧!如果你对我的文章有任何问题或者意见,欢迎在评论区给我留言。后期重点注释和知识点将持续更新......
边栏推荐
- Tensorflow steps on the pit notes and records various errors and solutions
- SQL(1) - Add, delete, modify and search
- LeetCode刷题之第1024题
- 亲身实感十多年的面试官面试的题目
- 【论文阅读-表情捕捉】High-quality Real Time Facial Capture Based on Single Camera
- 华科提出首个用于伪装实例分割的一阶段框架OSFormer
- 二、自动配置之底层注解
- 最简单的防抖节流理解法
- 读论文 - Unpaired Portrait Drawing Generation via Asymmetric Cycle Mapping
- 【Promise高级用法】实现并行和串行API
猜你喜欢
![[Practice 1] Diabetes Genetic Risk Detection Challenge [IFLYTEK Open Platform]](/img/10/7aa3153e861354178f048fb73076f7.png)
[Practice 1] Diabetes Genetic Risk Detection Challenge [IFLYTEK Open Platform]

读论文-Cycle GAN

哥廷根大学提出CLIPSeg,能同时作三个分割任务的模型

【数据库和SQL学习笔记】7.SQL中的插入(INSERT)、删除(DELETE)、更新(UPDATE)

【数据库和SQL学习笔记】3.数据操纵语言(DML)、SELECT查询初阶用法

5G中切片网络的核心技术FlexE

网工必用神器:网络排查工具MTR

1004 成绩排名 (20 分)

MySQL主从复制—有手就能学会的MySQL集群搭建教程

电子产品量产工具(4)-UI系统实现
随机推荐
IJCAI 2022|边界引导的伪装目标检测模型BGNet
leetCode刷题之第31题
It turns out that the MAE proposed by He Yuming is still a kind of data enhancement
【论文精读】Rich Feature Hierarchies for Accurate Object Detection and Semantic Segmentation(R-CNN)
五、请求处理—Rest映射是怎样实现的?
CAN、CAN FD
【数据库和SQL学习笔记】9.(T-SQL语言)定义变量、高级查询、流程控制(条件、循环等)
[Database and SQL study notes] 9. (T-SQL language) Define variables, advanced queries, process control (conditions, loops, etc.)
七、请求处理——Map、Model类型参数处理原理
Tensorflow2 与 Pytorch 在张量Tensor基础操作方面的对比整理汇总
[Pytorch study notes] 9. How to evaluate the classification results of the classifier - using confusion matrix, F1-score, ROC curve, PR curve, etc. (taking Softmax binary classification as an example)
A deep learning code base for Xiaobai, one line of code implements 30+ attention mechanisms.
WCH系列芯片CoreMark跑分
神经网络也能像人类利用外围视觉一样观察图像
HuiFer 带你读懂 BeanFactory getBean 方法
CVPR best paper winner Huang Gao's team from Tsinghua University presented the first dynamic network review
[Intensive reading of the paper] R-CNN's Bounding box regression problem is detailed
教你如何封装功能组件和页面组件
基于STM32F407的WIFI通信(使用的是ESP8266模块)
Redis设计与实现(第一部分):数据结构与对象