首先,在内存分配上,如果是单独的一个数据类型,对齐方式如下:
常用类型的对齐方式
类型 对齐方式(变量存放的起始地址相对于结构的起始地址的偏移量)
char 偏移量必须为sizeof(char)即1的倍数
int 偏移量必须为sizeof(int)即4的倍数
double 偏移量必须为sizeof(double)即8的倍数
short 偏移量必须为sizeof(short)即2的倍数
float 偏移量必须为sizeof(float)即4的倍数
比如:如果是一个char类型数组,每一个元素相对于起始地址的偏移量应该是1、2、3…..
如果是一个int类型数组,每一个元素相对于起始地址的偏移量应该是4、8、12、16…..
那么,问题来了,如果不是一个数组而是一个结构体,这个结构体中包含了不同类型的数据,比如:
struct MyStruct
{
double doub;
char ch;
int i;
};
这个结构体中包含了三个不同类型的变量,那么在同一块连续的内存空间上,如果单独的为其中的某个变量分配空间,无论有多少个同类型的变量,那将是很容易的,只要根据单个变量的对齐规则,按先后顺序以及规定的偏移量顺序分配内存空间岂可。但是现在这个结构体中有三个不同类型的变量,这三个变量的其实地址都是这个结构体的起始地址,但是要按照他们各自的对齐规则将他们顺序的放到一条连续的内存空间上并且不能产生重叠干涉,这就是结构体内存对其的问题了。
首先doub作为第一个变量,对齐规则是8、16、32、、由于前面没有变量,地址空间空闲,那么他的内存地址为1-8.
第二个变量ch为char类型,对齐规则为1、2、3、、、由于前面的0-8已经被占用,那么它的起始地址自动转到9.那么他的内存地址就为9-9.
第三个变量i为int型,对齐规则为4、8、12、、、、由于前面的1-8已经被doub占用了,9-12这段内存中的9也被ch占用了,那么i只能选择13-16这段内存空间了,10-12就被空闲了。
这就是结构体中的内存对其。