//我的电脑是64位#includestruct sum
{
short d;
};
int main(void)
{
sum s;
int summ;
summ=sizeof s;
printf("%d",summ);
}
结果为:2,因为short型占2个字节
2.
#includestruct sum
{
short d;
int a;
};
int main(void)
{
sum s;
int summ;
summ=sizeof s;
printf("%d",summ);
}
结果为:8 因为short型占2个字节,int占4个字节,但是struct默认的对齐方式是它的最长成员的对齐方式,在此处最长成员是int型占4个字节。所以会对short型做边界补齐,填充了两个字节。所以为4+4=8.
3.
#includestruct sum
{
char t;
char *c;
};
int main(void)
{
sum s;
int summ;
summ=sizeof s;
printf("%d",summ);
}
结果为 16. char *占8个字节。对char补齐为8个字节后,结果为16. 注意:struct的总大小为结构体最长成员的整数倍
4.
#includestruct sum
{
short d;
char t[5];
};
int main(void)
{
sum s;
int summ;
summ=sizeof s;
printf("%d",summ);
}
结果为8, 2+5+1(补齐,因为short型占2个字节,且为最长成员①,所以t[5],为2+2+1,还差一个字节,所以再补一个字节即 5+1) ①:因为数组也是复合型数据类型,所以在寻找最宽的成员时,应当包括复合型类型成员的子成员,而不是将其看成整体!