从底层来说,计算机访问内存的两种方式:
从为word_size(比如32位或者64位)的倍数的地址开始,
1. 读取长度为word_size的内存块的数据,或者
2. 把长度为word_size的数据写入内存。
这里有两个“天性”【注释1】:
1. 读/写总是从word_size的倍数的地址开始的(wikipedia上Data Structure Alignment词条独独少了这条至关重要的说明,虽然从其上下文可以推断出来)
2. 读/写的长度总是word_size的倍数
比如在一台64位的计算机上,读取一块1k的内存,CPU需要进行的读取操作次数是:
基于这两个天性,内存对齐这个概念,包含两个方面:
1. 内存块地址的对齐
指的是内存块的地址(即一块内存的首字节的地址)是word_size的倍数;用几个例子来说明这个意思:
1)在一台32位计算机上的内存里,某个int型变量i在内存中的地址是0x7B163E00;
2)某个char变量c在内存中的地址是0x7B163D00,等等
内存地址不对齐,会引起什么样的问题呢?用一个例子来说明:
假定在一台32位机器上,有一个整型变量i的地址是34 【注释2】,那i存储在内存的34、35、36、37地址;
为了把这个变量从内存读进CPU,由于计算机从内存读取数据的天性(第一