C/C++内存对齐

注:以下在32位情况下讨论

先看现象,有这么几行代码

复制代码
#include<stdio.h>
struct test{
int a;
char b;
int c;
}typedef test;
int main(){
    int cnt=sizeof(test);
    printf("%d",cnt);
    return 0;
}

在我们不知道内存对齐前,很可能认为结构体大小是4+1+4=9,可实际结果是12

为什么会造成这样的现象?那就需要了解结构体的内存对齐了

结构体对齐规则

首先,先列出内存对齐的规则

  1. 结构体的首个成员始终从结构体变量的起始位置(偏移量为0)开始存储
  2. 其余成员变量需按其对齐数的整数倍地址进行存储
    • 对齐数取值为:编译器默认对齐数与该成员类型大小的较小值
    • Visual Studio 默认对齐数为8
    • Linux GCC 无默认对齐数,直接使用成员自身大小作为对齐数
  3. 结构体总大小必须是最大成员对齐数的整数倍
  4. 对于嵌套结构体的情况:
    • 嵌套的结构体按其成员中的最大对齐数进行对齐
    • 整个结构体的大小须为所有对齐数(包括嵌套结构体成员的对齐数)中最大值的整数倍

也就是说结构体内三个变量的地址并不是连续的,而是4+4+4=12,并未想当然的4+1+4=9

为什么需要内存对齐?

首先内存对齐的直接目的就是为了提高 cpu的效率,cpu一次性读取4个字节,当读取变量c时,会产生一个很dan疼的事,4+4+1变成这样读取,也就是 c的前三个字节和最后一个字节没有一起读取,所以要分两次读取导致cpu读取效率下降,也就是为什么需要内存对齐最直接最主要的原因。

练习

内存对齐结果如下

相关推荐
她的男孩3 小时前
Spring Boot 接 Flowable 工作流:用 3 个注解搭一个请假审批流程
java·后端·架构
荣码4 小时前
LLM结构化输出:让AI返回JSON而不是废话,我踩了4个坑
java·python
plainGeekDev6 小时前
Gson → kotlinx.serialization
android·java·kotlin
小bo波14 小时前
Java Swing 图形用户界面实验 —— 从算术练习到游戏开发的完整实践
java·课程设计·gui·游戏开发·扫雷·swing
咖啡八杯16 小时前
GoF设计模式——备忘录模式
java·后端·spring·设计模式
apocelipes18 小时前
常用编程语言和库的正则表达式性能对比
c语言·c++·python·性能优化·golang·开发工具和环境
SamDeepThinking1 天前
裁掉那个差程序员后,给你看团队里高手的代码:这个习惯,希望你有
java·后端·程序员
朕瞧着你甚好1 天前
技术雷达 & Java 集成评估报告 — Apache Tika 3.3.1
java·ai编程