内存字节对齐

来源:互联网 发布:网站源码授权程序 编辑:程序博客网 时间:2024/06/08 02:35

原文点这里
要点:
1. 数据成员对齐规则:结构(struct)(或联合(union))的数据成员,第一个数据成员放在offset为0的地方,以后每个数据成员存储的起始位置要从该成员大小或者成员的子成员大小(只要该成员有子成员,比如说是数组,结构体等)的整数倍开始(比如int在32位机为4字节,则要从4的整数倍地址开始存储。
2. 结构体作为成员:如果一个结构里有某些结构体成员,则结构体成员要从其内部最大元素大小的整数倍地址开始存储(struct a里存有struct b,b里有char,int ,double等元素,那b应该从8的整数倍开始存储)。
3. 收尾工作:结构体的总大小(也就是sizeof的结果)必须是其内部最大成员的整数倍,不足的要补齐。

示例:

typedef struct bb{ int id;         // [0]...[3] double weight;  // [8]...[15]  原则1 float height;   // [16]...[19]  总长要为8的整数倍,补齐[20]...[23]  原则3}BB;typedef struct aa{ char name[2];  // [0]...[1] int  id;       // [4]...[7]  原则1 double score;  // [8]...[15] short grade;   // [16]...[17] BB b;          // [24]...[47]  原则2}AA;int main(){  AA a;  cout<<sizeof(a)<<" "<<sizeof(BB)<<endl;  // 在#pragma pack(8)的情况下输出:48 24  return 0;}
0 0
原创粉丝点击