union和struct区别

来源:互联网 发布:皇室战争电击法术数据 编辑:程序博客网 时间:2024/06/05 05:14

Typedef union student

{

       Char name[10]

       Long sno;

       Char sex;

       Float score [4];

} STU;

 

Main ()

{

      STU a[5]

      Printf(“%d\n”,sizeof(a)

}

答案是80 ,因为union是可变的以其成员中最大的成员作为 该union的大小!

但是换成是 struct又是多少呢?

Typedef struct student

{

       Char name[10]

       Long sno;

       Char sex;

       Float score [4];

} STU;

 

Main ()

{

      STU a[5]

      Printf(“%d\n”,sizeof(a)

}

答案是 180  ????为什么不是 (10+4+1+16)*5=155?

因为struct 有个叫对齐方式的问题:不对齐的数据存取在x86上影响速度,因为在不对齐的时候,对于小的可能会影响其效率,对齐即是多分配一些字节,填充无用数据,以空间的损失来换取消率。

struct是一种复合数据类型,其构成元素既可以是基本数据类型(如int、long、float等)的变量,也可以是一些复合数据类型(如array、struct、union等)的数据单元。对于结构体,编译器会自动进行成员变量的对齐,以提高运算效率。缺省情况下,编译器为结构体的每个成员按其自然对齐(natural alignment)条件分配空间。各个成员按照它们被声明的顺序在内存中顺序存储,第一个成员的地址和整个结构的地址相同。

自然对齐(natural alignment)即默认对齐方式,是指按结构体的成员中(类型)size最大的成员作为基本的分配单元,而且与其顺序有这密切的联系。

例如:

struct naturalalign
   {
       char a;
       short b;
       char c;
   };

在上述结构体中,size最大的是short,其长度为2字节,因而结构体中的char成员a、c都以2为单位对齐,sizeof(naturalalign)的结果等于6;

如果改为:

struct naturalalign
   {
       char a;
       int b;
       char c;
   };

其结果显然为12。

那么再回到到原题:结构体中,size最大的是long,size是 4,所以,按照顺序,Char name[10];12个字节;Long sno; 4个字节;Char sex; 4个字节(这里对齐了);Float score [4]; 16个字节。于是(12+4+4+16)×5=180,就是了!

刚才还说过,与顺序有关,呵呵,我们改一下:

Typedef struct student

{

       Char name[10]

       Char sex;

       Long sno;

       Float score [4];

} STU;

 

Main ()

{

      STU a[5]

      Printf(“%d\n”,sizeof(a)

}

答案是:160. 为什么,只是换了顺序而已呀?关键就在顺序上。

结构体中,size最大的是long,size是 4,所以,按照顺序,Char name[10];12个字节;但是这12中多分配的2个字节可以包含后面的Char sex; (问题就在这);Float score [4]; 16个字节。于是(12+4+16)×5=160,就是了!

所以要小心呀!

 

 

2.2指定对齐

一般地,可以通过下面的方法来改变缺省的对齐条件:

· 使用伪指令#pragma pack (n),编译器将按照n个字节对齐;
  · 使用伪指令#pragma pack (),取消自定义字节对齐方式。

注意:如果#pragma pack (n)中指定的n大于结构体中最大成员(类型)的size,则其不起作用,结构体仍然按照size最大的成员进行对齐。

     例如:

#pragma pack (n)
       struct naturalalign
      {
            char a;
            int b;
            char c;
      };
#pragma pack ()

当n为4、8、16时,其对齐方式均一样,sizeof(naturalalign)的结果都等于12。而当n为2时,其发挥了作用,使得sizeof(naturalalign)的结果为6。

  1. // C++_practice.cpp : 定义控制台应用程序的入口点。  
  2. //  
  3.   
  4. #include "stdafx.h"  
  5. #include "stdlib.h"  
  6. #pragma pack (1)  
  7. typedef union student1  
  8. {  
  9.        char name[10];  
  10.        long sno;  
  11.        char sex;  
  12.        float score [4];  
  13. } STU;  
  14. typedef struct student2  
  15. {  
  16.        char name[10];  
  17.        long sno;  
  18.        char sex;  
  19.        float score [4];  
  20. } STS1;  
  21. typedef struct student3  
  22. {  
  23.        char name[10];  
  24.        char sex;  
  25.        long sno;  
  26.        float score [4];  
  27. } STS2;  
  28. int _tmain(int argc, _TCHAR* argv[])  
  29. {  
  30.     STU a[5];  
  31.     STS1 b[5];  
  32.     STS2 c[5];  
  33.       printf("%d\n",sizeof(a));  
  34.       printf("%d\n",sizeof(b));  
  35.       printf("%d\n",sizeof(c));  
  36.       system("pause");  
  37.     return 0;  
  38. }  
原创粉丝点击