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读取效率下降,也就是为什么需要内存对齐最直接最主要的原因。

练习

内存对齐结果如下

相关推荐
SimonKing3 小时前
OpenCode AI辅助编程,不一样的编程思路,不写一行代码
java·后端·程序员
FastBean4 小时前
Jackson View Extension Spring Boot Starter
java·后端
Seven975 小时前
剑指offer-79、最⻓不含重复字符的⼦字符串
java
皮皮林55114 小时前
Java性能调优黑科技!1行代码实现毫秒级耗时追踪,效率飙升300%!
java
冰_河14 小时前
QPS从300到3100:我靠一行代码让接口性能暴涨10倍,系统性能原地起飞!!
java·后端·性能优化
桦说编程17 小时前
从 ForkJoinPool 的 Compensate 看并发框架的线程补偿思想
java·后端·源码阅读
躺平大鹅19 小时前
Java面向对象入门(类与对象,新手秒懂)
java
初次攀爬者20 小时前
RocketMQ在Spring Boot上的基础使用
java·spring boot·rocketmq
花花无缺20 小时前
搞懂@Autowired 与@Resuorce
java·spring boot·后端