exg1:
struct name1
{
char str; 占用空间:2个字节
short x; 占用空间:2个字节
int num; 占用空间:4个字节
double xx; 占用空间:8个字节
};
{
char str; 占用空间:2个字节
short x; 占用空间:2个字节
int num; 占用空间:4个字节
double xx; 占用空间:8个字节
};
就拿这个来说 struct 的相对起始地址为0x00000000,char是一字节,因此short本来应该的地址是0x00000001,但是由于字节对齐,因此short要在相对起始地址是2的倍数的位置,因此是在0x00000002的位置上了,然后char+short的地址是4字节,因此int的起始位置是0x00000004,很符合4的倍数,不用动,double xx则正好符合8的倍数
exg2:
struct name2
{
char str; 占用空间:4个字节
int num; 占用空间:4个字节
short x; 占用空间:8个字节
double xx; 占用空间:8个字节
};
struct name2=24个字节 //加起来是18个字节,但是要是sizeof(double)的倍数,所以为24。
{
char str; 占用空间:4个字节
int num; 占用空间:4个字节
short x; 占用空间:8个字节
double xx; 占用空间:8个字节
};
struct name2=24个字节 //加起来是18个字节,但是要是sizeof(double)的倍数,所以为24。
exg3:
struct name1
{
char str; 偏移为0 ,从第一个字节位置存储,占1个字节
short x; 偏移为2 , 从第三个字节位置开始存储,占2个字节
int num; 偏移为4, 由于前两个占了4个字节,所以从第五个字节开始存储。占4个字节
double xx; 偏移为8,由于前两个占了8个字节,所以从第9个字节开始存储。占8个字节
{
char str; 偏移为0 ,从第一个字节位置存储,占1个字节
short x; 偏移为2 , 从第三个字节位置开始存储,占2个字节
int num; 偏移为4, 由于前两个占了4个字节,所以从第五个字节开始存储。占4个字节
double xx; 偏移为8,由于前两个占了8个字节,所以从第9个字节开始存储。占8个字节
};
一共占16个字节。
转载:http://blog.csdn.net/hbyh/article/details/2061471
一共占16个字节。
exg5:
如果碰到结构体中有字符数组,例如:
struct para{
int iId;
char name[10];
char valuce[11];
}
它在内存中所占的空间大小为:4+10+11=25
注意:图2(红色的字图片)中的int是按照2来计算的。
其实,看上面的第三个例子 exg3 就知道内存怎么对齐的了!!!!