32位和64位下结构体大小判断、内存对齐问题

转载自:原文链接:https://blog.csdn.net/lyh__521/article/details/45958847

 

1.先看64位下:
#include
struct A
{
    int   a;
    char  b;
    double c;
    char  d;
};

struct B
{
    char  a;
    double b;
    char  c;
};

int main()
{
    printf("int =%lu,char=%lu,double=%lu\n",sizeof(int),sizeof(char),sizeof(double));
    printf("structA=%lu  structB=%lu\n",sizeof(struct A),sizeof(struct B));
    return 0;
}
int:4

char:1

double:8

structA: 4+(1+3)+8+(1+7) = 24
structB: (1+7)+8+(1+7) = 24
计算结果与输出是一样的。
这两个结构体在内存中存储应该是下面这样的:
32位和64位下结构体大小判断、内存对齐问题_第1张图片
2.在32位下编译,gcc 加参数 -m32


#include
struct A
{
    int   a;
    char  b;
    double c;
    char  d;
};

struct B
{
    char  a;
    double b;
    char  c;
};

int main()
{
    printf("int =%u,char=%u,double=%u\n",sizeof(int),sizeof(char),sizeof(double));
    printf("structA=%u  structB=%u\n",sizeof(struct A),sizeof(struct B));
    return 0;
}

结果和64位下完全不一样,很显然它没有按照最长成员double的8字节对齐。稍微想一下就明白了,因为32位只有4个字节,最长对齐模数只能按4个字节来对齐,double 是分成了2个4字节。上面两个结构体在内存中应该是这种形式。

32位和64位下结构体大小判断、内存对齐问题_第2张图片

(1+3)+8+(1+3) = 16

内存空间实际上是连续的,上面分块的画法只是为了方便理解。

3.关于内存对齐的介绍
http://blog.csdn.net/csw_100/article/details/5495309
 

 

 

增加:

double 8个字节
int 4个字节
float4个字节
short 2个字节
char 1个字节
enum {green,red,black} color; 占4个字节不管枚举多少个
union 联合体所占字节数为,里边包含最大的一个如包含{ int a[8]; char k;}则sizeof为8*4=32


struct A  
{  
      short i;  
      struct   
      {  
           char c;  
           int j;  
      } ss;   
      int k;  
}  

sizeof(A)=(1+3)+(1+3+4)+4=16

如下结构体是特例
struct A 
{  
    float f;  
    char p;  
    int adf[3];  
}; 
将数组展开,为3个int
sizeof(A)=4+4+3*4=20
 

你可能感兴趣的:(32位和64位下结构体大小判断、内存对齐问题)