内存对齐模式
前言
大家可能都遇到过这个情况,一个结构体的sizeof()大小总是比你算出来的大,甚至结构体中的实例位置不一样,其真实大小都会发生改变,这是为什么呢?
这就是这篇博文为大家介绍的计算机的一个机制,内存对齐模式。
下面做一个验证,关于结构体的大小。代码如下👇
#include <stdio.h>
typedef struct STI {
char code[8];
char name[20];
char sex[4];
short age;
int mathScore;
int csScore;
int englishScore;
}STI;
int main() {
int size;
size = sizeof(STI);
printf("sizeof(STI) = %d\n", size);
return 0;
}
结果如下👇
让我们来计算一下这个结构体的大小。
char[8] + char[20] + char[4] = 1 * 32 = 32 byte
short = 2 byte
int * 3 = 4 * 3 = 12 byte
所以,sizeof(STI) = 32 + 2 + 12 = 46 byte
但是真实的STI大小为48。
这种诡异的现象就是操作系统中的“内存对齐模式”倒置的。
若要了解内存对齐模式,则需要了解内存页式管理,若要了解内存页式管理,则需要了解连续存储空间分配管理模式,因此我逐层讲起,先来介绍连续存储空间分配管理模式。
Ⅰ 连续存储空间分配管理模式
原谅我拙劣的画技,假设有个内存如下,其编号为0到1000。
我们知道,最前面和最后面的空间是不能用的,它们属于操作系统。假设编号为0-100,以及900-1000,这两段为不可用的操作系统所占的空间。
已使用空间编号 | |
---|---|
未使用空间编号 | 100~900 |
现在我调用QQ进内存,打开这个软件。假设QQ需要占用内存150个单位空间大小。