内存对齐:编译器将程序中的每个数据安排在合适的位置上,而不是连续地,可以在相当大的程度上提高程序性能。
原理:计算机内存是以字节(Byte)为单位划分,实际情况中CPU不可任意访问某个字节。CPU 通过地址总线来访问内存,比如说32 位的 CPU 一次可以处理4个字节的数据,那么每次就从内存读取4个字节的数据;也就是说寻址的步长为4个字节,即只对编号为 4 的倍数的内存寻址。这样做可以快速寻址寻址,不遗漏,也不重复。若一个变量最好位于一个寻址步长的范围内,这样一次就可以读取到变量的值;如果跨步长存储,就需要读取两次,然后再拼接数据,效率显然降低了。将一个数据尽量放在一个步长之内,避免跨步长存储,这称为内存对齐。在32位编译模式下,默认以4字节对齐;在64位编译模式下,默认以8字节对齐。为了提高存取效率,编译器会自动进行内存对齐,这是一种空间换时间的做法。
内存对齐虽然和硬件有关,但是决定对齐方式的是编译器,如果你的硬件是64位的,却以32位的方式编译,那么还是会按照4个字节对齐。
内存对齐属于计算机的运行原理,C语言、C++等其他编程语言也有。