今天遇到一个问题,自写了一个结构体,调试后发现结构体字节数跟每个成员的字节数和不等,代码如下:
#include <stdio.h>
struct ether_header
{
unsigned char ether_dhost[6]; // 以太网目的地址--占1*6个字节
unsigned char ether_shost[6]; // 源以太网地址--占1*6个字节
unsigned char ether_headlen ; //包头长--占1个字节
unsigned int ether_pktNO ; //数据包编号--占4个字节
unsigned short ether_datalen; // 数据包长--占2个字节
};
int main()
{
printf("%d\n", sizeof(struct ether_header)); //运行后打印出24
return 0;
}
打印后的结果与各成员的字节数19不等,而实际struct ether_header占24个字节;经过分析后得知内存是按四字节对齐的,故为24。
结论:内存是按照一定的字节数对齐的。
补充三条:
1:数据成员对齐规则:结构(struct)(或联合(union))的数据成员,第一个数据成员放在offset为0的地方,以后每个数据成员存储的起始位置要从该成员大小或者成员的子成员大小(只要该成员有子成员,比如说是数组,结构体等)的整数倍开始(比如int在32位机为4字节,则要从4的整数倍地址开始)存储。
2:结构体作为成员:如果一个结构里有某些结构体成员,则结构体成员要从其内部最大元素大小的整数倍地址开始存储。(struct a里存有struct b,b里有char、int 、double等元素,那b应该从8的整数倍开始存储。)
3:收尾工作:结构体的总大小,也就是sizeof的结果,必须是其内部最大成员的整数倍,不足的要补齐。
更多参看:《内存分配的字节对齐》