Chinaunix首页 | 论坛 | 博客
  • 博客访问: 384197
  • 博文数量: 43
  • 博客积分: 1493
  • 博客等级: 上尉
  • 技术积分: 660
  • 用 户 组: 普通用户
  • 注册时间: 2008-05-01 10:57
文章分类

全部博文(43)

文章存档

2015年(1)

2013年(1)

2011年(6)

2010年(13)

2009年(13)

2008年(9)

分类:

2009-10-17 16:46:03


sizeoof的分析


很多时候会碰到sizeof(struct A)=?这样的问题,不管是考试,还是面试,领导们都喜欢出这样的问题,今天决定详细讨论一下;
先看下面的例子:
        
struct a
{
    char no[10];
    int p;
    long int pp;
    unsigned int ppp;
    char x;
    float y;
    double h;
}xy;
struct BF1
{
char f1 : 3;
char f2 : 4;
char f3 : 5;
};
struct BF2
{
char f1 : 3;
short f2 : 4;
char f3 : 5;
};
struct b
{
    char i;
    short j:2;
    long k:1;
};
struct B{
    int a;
    double b;
    char c[100];
    long d;
};
typedef struct Test
{
    short  a;
    char   b;
    double c;
    char   d;
    char   e;
    char   f;
    char   g;
}sTest;
void main()
{
    printf("char no:     %d \n",sizeof(xy.no));
    printf("int p:       %d \n",sizeof(xy.p));  
    printf("long int pp: %d \n",sizeof(xy.pp));
    printf("unsigned ppp:%d \n",sizeof(xy.ppp));
    printf("char x:      %d \n",sizeof(xy.x));
    printf("float y:     %d \n",sizeof(xy.y));
    printf("double h:    %d \n",sizeof(xy.h));
    printf("struct a:    %d \n",sizeof(struct a));
    printf("size of bf1 %d\n",sizeof(struct BF1));
    printf("size of bf2 %d\n",sizeof(struct BF2));
    printf("sizeof b is %d\n",sizeof(struct b));
    printf("sizeof B is %d\n",sizeof(struct B));
    printf("sizeof stest is %d\n",sizeof(sTest));
}
对结构体里面的变量的sizeof值,不会有对齐的问题,该是多少就是多少。
所以:
   printf("char no:     %d \n",sizeof(xy.no));
    printf("int p:       %d \n",sizeof(xy.p));  
    printf("long int pp: %d \n",sizeof(xy.pp));
    printf("unsigned ppp:%d \n",sizeof(xy.ppp));
    printf("char x:      %d \n",sizeof(xy.x));
    printf("float y:     %d \n",sizeof(xy.y));
    printf("double h:    %d \n",sizeof(xy.h));
的答案就是:
char no:     10
int p:       4
long int pp: 8
unsigned ppp:4
char x:      1
float y:     4
double h:    8
这里需要注意的是sizeof(long)的值,我的机子是8,所以所有的值都是以8来算的,如果你的机子值为4,那么下面的有关long的答案都需要作相应的修改。
再看
printf("struct a:    %d \n",sizeof(struct a));
这里就比较有意思了:
看看它的内容是这样的,
struct a
{
    char no[10];
    int p;
    long int pp;
    unsigned int ppp;
    char x;
    float y;
    double h;
}xy;
它的值=10+2(对齐)+4+8+4+1+3(对齐)+4+8+4(对齐)=48
括号里面这些对齐的值怎么来的呢?
1,因为int p占用四个字节,而no变量占用10个字节,10并不是4的倍数,所以要加2才能除以4;
2,float x占用4个字节,而float x之前占用了29个字节,29加3才可以除以4,所以要加3;
3,如果不加最后的4,那么一共是44个字节,44必须等被这个结构体里面的最大的数据类型的空间对齐,
最大是long int和double都等于8,所以44+4才可以除以8,于是最后的值就是48了。
有了上面的解释,我想其它的就都可以解释了;
有关位域的留在后面讲,先看类似的巩固一下上面的解释:
struct B{
    int a;
    double b;
    char c[100];
    long d;
};
sizeof(struct B)=?
sizeof(struct B)=4+4(对齐)+8+100+4(对齐)+8=128;
算对了吗?
再来一个:
typedef struct Test
{
    short  a;
    char   b;
    double c;
    char   d;
    char   e;
    char   f;
    char   g;
}sTest;
sizeof(sTest)=?
sizeof(sTest)=2+1+5(对齐)+8+1+1+1+1+4(对齐)=24;
算对了吗?
下面看看有关位域的:
struct BF1
{
char f1 : 3;
char f2 : 4;
char f3 : 5;
};
sizeof(struct BF1)=3+4+5=12bits
大于1个字节小于2个字节,所以只能是分配2个字节了;
struct BF2
{
char f1 : 3;
short f2 : 4;
char f3 : 5;
};
sizeof(struct BF2)=3+4+5=12bits
最后还是2个字节,注意这个值在不同的平台不一样,在VC上等于4个字节;
struct b
{
    char i;
    short j:2;
    long k:1;
};
这个呢?
sizeof(struct b)=8+2+1=11bits
也就是2个字节,但是需要和long对齐,所以结果就是8了;
最后来看看有关几个字符串的:
char *str="0123456";
sizeof(str)=? 
sizeof(*str)=?
strlen(str)=?
char str1[]="0123456";
sizeof(str1)=?
sizeof(*str1)=?
strlen(str1)=?
char str2[10]="0123456";
sizeof(str2)=?
sizeof(*str2)=?
strlen(str2)=?
sizeof(str)=8;sizeof(str1)=8;sizeof(str2)=10;
sizeof(*str)=1;sizeof(*str1)=1;sizeof(*str2)=1;
strlen(str)=7;strlen(str1)=7;strlen(str2)=7;
OK了。



阅读(1399) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~