内存对齐,对于c系语言来说,直接用#pragma pack(n),n可以为1,2,4,8,16,32等2的次方数.
当然,在不接触到底层的编程中,很少会使用到这个功能.
但是还是需要知道有这个对齐原则,以及它存在的理由:
同时,成员分配完之后,还要对结构体补齐.
当然,在不接触到底层的编程中,很少会使用到这个功能.
但是还是需要知道有这个对齐原则,以及它存在的理由:
对于结构体,联合而言,第一个结构体成员的地址偏移量必然是0,对于之后的成员,地址偏移量必须是
在n和该结构体的成员中自身大小中较小的那个值.
这也就是说,当n值大于该结构体中所有成员的大小时,#pragma pack(n)是不起作用的.同时,成员分配完之后,还要对结构体补齐.
内存所分配的字节数,必须是x这个数值的整数倍,
而x则是n和结构体中最大成员中较小的那个值.
这么做最直观的一个好处就是,CPU每一次读取内存的大小是相同的(大多数都是一个字长).
假设有2个相邻的长度为字长的内存空间m1,m2,数据A分为a1放在m1的高字节,而a2则放在m2的低字节,那么对于cpu读取数据A到寄存器要做的工作就至少需要多一倍的开销.
根据我在VS2010中的测试,VS默认的n值为8.