Chinaunix首页 | 论坛 | 博客
  • 博客访问: 248000
  • 博文数量: 83
  • 博客积分: 10
  • 博客等级: 民兵
  • 技术积分: 410
  • 用 户 组: 普通用户
  • 注册时间: 2012-08-22 10:11
文章分类
文章存档

2016年(2)

2014年(2)

2013年(65)

2012年(14)

我的朋友

分类: C/C++

2013-01-24 11:32:32

原文地址:Sruct 与 Union 的内存分配 作者:11wping

Struct

     struct的内存大小为每个数据内存的加和,首先按照最大的数据类型进行单个分配,如果前一个数据占用不了所有的内存,而剩下的内存可以放下下一个数据,则第二个数据不另外分配内存,否则重新分配一个最大类型的内存单元

Union

     Union的大小为其内部所有变量的最大值,并且按照类型最大值的整数倍进行内存对齐

示例1:

  Union data1

{

  double  d;

  int     i;

  char    c1;

  char    c2[9]; 

};

  sizeof(union data1)的值为16.在编译器默认设置的情况下,该共用体最大基本类型为double,它占8字节,所以此共用体以8来对齐。字符数组c2占9个字节,那么整个共用体应该占9个字节,但按照对齐原则,实际分配给它的内存为16字节

struct data1

  {

     double  d;

     int         i;

     char      c1;

     char      c2[9];

   };

sizeof(struct data1)的值为24,首先按照存储大小,该结构体所占存储空间为:8+4+1+9=22字节,这个结构体也是以8对齐,因此实际分配的是8+8+16=24字节(给i分配8个字节,c1就不需要另外再分配空间了,c2分配8*2=16字节)。

示例2:

   Union data2

{

  int       i;

  char    c1;

  char    c2[9]; 

};

   sizeof(union data2)的值为12,该共用体占内存空间最大的基本数据类型为int,其长度为4,所以该共用体以4来对齐。该共用体的长度取决于字符c2,其长度为9,9不是4的倍数,要进行对齐,因此实际分配的存储空间为12.

  struct data2

  {

     int         i;

     char      c1;

     char      c2[9];

   };

    sizeof(struct data2)的值为16,与上面共用体一样,该结构体以4对齐。按照存储大小,该结构体所占存储空间为:4+1+9=14,14不是4的倍数,进行对齐,对齐后的值为16=4+4+8.

示例3:

   Union data3

{

   char    c1;

  char    c2[3]; 

};

   sizeof(union data3)的值为3,该共用体占内存空间最大的基本数据类型为chart,其长度为1,所以该共用体以1来对齐。该共用体的长度取决于字符c2,其长度为3,因此分配的存储空间为3.

  struct data3

  {

     char      c1;

     char      c2[2];

   };

    sizeof(struct data3)的值为3,与上面共用体一样,该结构体以1对齐。按照存储大小,该结构体所占存储空间为:1+2=3字节。

示例4:

struct inner

{

   char       c1;

   double   d;

   char      c2;

}; // 8+8+8=24

这个结构体显然是8字节对齐的,在给c1分配存储空间时,考虑到对齐,分配给c1的字节数就是8,然后给d分配8字节,最后给c2分配时,因为也要以8对齐,所以也分配了8个字节的存储空间。所以sizeof(struct inner)值为24.

如果是:

  struct inner

{

   char       c1;

   char      c2;

   double   d;

}; // 8+8=16

当然这个结构体也是以8字节对齐的,编译器编译程序时,给c1、c2分配存储空间没有必要各自给它们分配8字节,只要8字节就可以了。给d分配8字节,所以sizeof(struct inner)值为16.

struct inner

{

   char       c1;

   double   d;

   char      c2;

};  //24

  union data4

   {

      struct   inner t1;

      int            i;

      char         c;

    }; // 24

  由于data4共用体中有一个inner结构体,所以最大的基本数据类型为double,因此以8字节对齐。共用体的存储长度取决于t1,而t1长度为24,因此sizeof(union data4)的值为24.

struct inner

{

   char       c1;

   double   d;

   char      c2;

}; // 24

  struct data4

   {

      struct   inner t1;

      int            i;

      char         c;

    };

data4结构体中有一个inner结构体,所以以8对齐,变量i和c共分配8字节就可以了,因此sizeof(struct data4)的值为32.

示例5:

struct  data

  {

      int       a;

      long    b;  //8

      double  c;   //8

      float     d;

      char     e;

      short    f;  //8

   }d;

这个结构体所占的字节数是多少呢?这里假设long所占字节数为4字节,short占2字节。这个结构体与示例4中第二个struct inner类似。首先这个结构体是以8字节对齐的,因为最长基本数据类型为double,它占8字节,d、e、f、总和为7个字节。分配存储空间时,成员a和b各分配4字节,d分配4字节,f分配2字节,e也分配2字节。d、e、f总和刚好占8个字节,所以sizeof(struct data)值为24.

struct  data

  {

      int       a;

      long    b;   // 8

      double  c;   // 8

      float     d;

      char     e[3];   //8

      short    f;  //8

   }d;

sizeof(struct data)值为32.

 

给定结构

  struct A

   {

      unsigned short t:4;   // 4表示位

      unsigned short k:4;

      unsigned short i:8;

      unsigned long m;

    };

问sizeof(A)的值。

程序分析:unsigned short 一般占2个字节,unsigned long一般占4个字节,结构体A以4字节对齐A中成员t、k、i共占4+4+8=16位 即2个字节由于要内存对齐实际那三个成员共占32位即4字节,成员m占4字节,因此sizeof(A)=8.

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