C语言深度理解之——结构体内存对齐

2024-03-15 22:52

本文主要是介绍C语言深度理解之——结构体内存对齐,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言:

在C语言中,结构体(struct)是一种用户自定义的数据类型,可以包含不同类型的数据成员。在定义结构体时,编译器会根据平台的要求对结构体的内存进行对齐,以提高内存访问的效率。结构体内存对齐可以避免因为数据成员的排列顺序不同而导致的内存浪费和性能问题。

目录

前言:

1. 结构体内存对齐原则

2. 默认对齐数

3. 修改默认对齐数

4. 代码示例


1. 结构体内存对齐原则

在C语言中,结构体内存对齐的原则可以总结如下:

  • 结构体的起始地址必须是最宽基本类型成员的整数倍。
  • 结构体的每个成员相对于结构体的起始地址的偏移量必须是该成员大小的整数倍。
  • 结构体的总大小必须是最宽基本类型成员大小的整数倍。

2. 默认对齐数

在C语言中,默认的对齐数通常是编译器相关的,一般情况下默认对齐数是当前平台最宽基本类型的大小(例如在32位系统上是4字节,在64位系统上是8字节)。

3. 修改默认对齐数

在C语言中,可以使用#pragma pack(n)指令来修改默认的对齐数,其中n表示要设置的对齐数。这个指令告诉编译器按照n字节对齐数据成员,而不是按照默认的对齐数。

4. 代码示例

下面是一个简单的代码示例,演示了结构体内存对齐和修改默认对齐数的情况:

#include <stdio.h>// 默认对齐数
#pragma pack(1)// 定义一个结构体
struct Student {char name[20];int age;float score;
};int main() {printf("Size of struct Student: %lu bytes\\n", sizeof(struct Student));// 恢复默认对齐数#pragma pack()// 修改对齐数为4#pragma pack(4)struct Student s;printf("Size of struct Student with pack(4): %lu bytes\\n", sizeof(struct Student));return 0;
}

在上面的代码中,我们首先定义了一个结构体Student,包含一个字符数组、一个整型和一个浮点数。然后通过sizeof运算符可以获取结构体的大小。在main函数中,我们演示了如何使用#pragma pack指令来修改默认对齐数,以及如何恢复默认对齐数。

通过运行上述代码,您可以看到在修改对齐数为4时,结构体Student的大小会发生变化。这个例子展示了结构体内存对齐和修改默认对齐数的效果。


这篇文章讲解的就是C语言底层的东西,由于缺少图片的原因,这篇文章并不容易理解,有不懂的地方欢迎私信我或者在评论区指出,我将尽我所能进行帮助。

感谢观看,还请各位大佬留下一个小小的赞!!!

这篇关于C语言深度理解之——结构体内存对齐的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/813520

相关文章

认识、理解、分类——acm之搜索

普通搜索方法有两种:1、广度优先搜索;2、深度优先搜索; 更多搜索方法: 3、双向广度优先搜索; 4、启发式搜索(包括A*算法等); 搜索通常会用到的知识点:状态压缩(位压缩,利用hash思想压缩)。

usaco 1.3 Mixing Milk (结构体排序 qsort) and hdu 2020(sort)

到了这题学会了结构体排序 于是回去修改了 1.2 milking cows 的算法~ 结构体排序核心: 1.结构体定义 struct Milk{int price;int milks;}milk[5000]; 2.自定义的比较函数,若返回值为正,qsort 函数判定a>b ;为负,a<b;为0,a==b; int milkcmp(const void *va,c

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

【C++高阶】C++类型转换全攻略:深入理解并高效应用

📝个人主页🌹:Eternity._ ⏩收录专栏⏪:C++ “ 登神长阶 ” 🤡往期回顾🤡:C++ 智能指针 🌹🌹期待您的关注 🌹🌹 ❀C++的类型转换 📒1. C语言中的类型转换📚2. C++强制类型转换⛰️static_cast🌞reinterpret_cast⭐const_cast🍁dynamic_cast 📜3. C++强制类型转换的原因📝

基于UE5和ROS2的激光雷达+深度RGBD相机小车的仿真指南(五):Blender锥桶建模

前言 本系列教程旨在使用UE5配置一个具备激光雷达+深度摄像机的仿真小车,并使用通过跨平台的方式进行ROS2和UE5仿真的通讯,达到小车自主导航的目的。本教程默认有ROS2导航及其gazebo仿真相关方面基础,Nav2相关的学习教程可以参考本人的其他博客Nav2代价地图实现和原理–Nav2源码解读之CostMap2D(上)-CSDN博客往期教程: 第一期:基于UE5和ROS2的激光雷达+深度RG

韦季李输入法_输入法和鼠标的深度融合

在数字化输入的新纪元,传统键盘输入方式正悄然进化。以往,面对实体键盘,我们常需目光游离于屏幕与键盘之间,以确认指尖下的精准位置。而屏幕键盘虽直观可见,却常因占据屏幕空间,迫使我们在操作与视野间做出妥协,频繁调整布局以兼顾输入与界面浏览。 幸而,韦季李输入法的横空出世,彻底颠覆了这一现状。它不仅对输入界面进行了革命性的重构,更巧妙地将鼠标这一传统外设融入其中,开创了一种前所未有的交互体验。 想象

自定义类型:结构体(续)

目录 一. 结构体的内存对齐 1.1 为什么存在内存对齐? 1.2 修改默认对齐数 二. 结构体传参 三. 结构体实现位段 一. 结构体的内存对齐 在前面的文章里我们已经讲过一部分的内存对齐的知识,并举出了两个例子,我们再举出两个例子继续说明: struct S3{double a;int b;char c;};int mian(){printf("%zd\n",s

深入理解RxJava:响应式编程的现代方式

在当今的软件开发世界中,异步编程和事件驱动的架构变得越来越重要。RxJava,作为响应式编程(Reactive Programming)的一个流行库,为Java和Android开发者提供了一种强大的方式来处理异步任务和事件流。本文将深入探讨RxJava的核心概念、优势以及如何在实际项目中应用它。 文章目录 💯 什么是RxJava?💯 响应式编程的优势💯 RxJava的核心概念