内存对其linux在没有__attribute__((packed)) 的情况下(__attribute__作用是 设置函数结构等的属性,本文为了说明可以通过它,告诉编译器取消结构在编译过程中的优化对齐,按照实际占用字节数进行对齐,是GCC特有的语法)
1:数据成员对齐规则:
第一个数据成员放在offset为0的地方,以后每个数据成员存储的起始位置要从该成员自身大小或者成员的子成员大小(只要该成员有子成员,比如说是数组,结构体等)的整数倍开始(如int在32位机为4字节,则要从4的整数倍地址开始存储。
2:结构体作为成员:
如果一个结构里有某些结构体成员,则结构体成员要从其内部最大元素大小的整数倍地址开始存储(struct a里存有struct b,b里有char,int ,double等元素,那b应该从8的整数倍开始存储.)。
3:收尾工作:
结构体的总大小,也就是sizeof的结果,必须是其内部最大成员(有子成员的看子成员大小而不是总共大小)的整数倍,不足的要补齐。
#include <iostream>
using namespace std;
typedef struct bb
{
int id; //[0]....[3]
double weight; //[8].....[15]:原则1
int height; //[16]..[19](sizeof总长要为8的整数倍,补齐[20]...[23]:原则3)
} /* __attribute__((packed)) */ 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()
{
cout<<sizeof(AA)<<" "<<sizeof(BB)<<endl;
return 0;
}
结果: 48 24