目录
CPU 的内存对齐
我们知道现代 CPU 主要有 32bit 和 64bit 字长之分,指的是 CPU 的寻址能力,即:一次可以处理的数据量大小,由 CPU 和 Bus(总线)宽度共同决定。
- 32bit CPU:一次能够处理 32bit(4Byte)内存数据,内存寻址空间为 4GB。
- 64bit CPU:一次能够处理 64bit(8Byte)内存数据,内存寻址空间为 256GB。
所以,在 Linux 操作系统的虚拟地址空间中,为物理内存空间的编址和寻址实现了一种称为内存对齐(Memory Alignment)的内存访问方式,比如:32bit CPU 要求 4Byte 字节对齐,64bit CPU 要求 8Byte 字节对齐。
以下图为例,如果 32bit CPU 要访问的数据刚好为 4Byte 大小,并且刚好也是内存对齐的,那么 CPU 就只需要一次内存访问即可;相反,则需要 2 次访问(跨越了 2 个对齐空间),从而浪费了 CPU 时钟周期。