复合数据类型,结构体,联合,枚举

结构体的定义:
  struct name
  {
  int a;
  int b;
  }change;
  name是数据类型,即该结构体的数据类型。以后就可以直接用name来定义该数据类型的变量。change是该结构体类型的变量。
  结构体有几个特点:
  1 结构体是一种数据类型,并不占有内存。因此如果有如下定义:
  struct name{
  char a[10]=" abcd";
  int b;
  }change;
  这种写法是错误的,因为不能直接在结构体内对成员赋值。并没有内存。
  2 结构体所占内存的计算
  一般是各个成员类型的内存之和,但是还要注意与运行环境有关,像32位机,每次处理数据是四个字节四个字节的处理,因此对于结构体中成员类型内存应该是四的倍数,例如:
  struct name
  {
  int a;
  char b;
  char c;
  }change ;
  此时结构体的内存总和是4+4,8个字节。
  当交换三个变量的定义顺序,b a c顺序,此时的内存是4+4+4 =12个字节。
  但是 当成员中有一个short int 类型,此时就应该是2的倍数,因为short int 是两个字节,需要统一。
  3 变化结构体定义的形式 如
  (1 ) struct neme
  {
  int a;
  int b;
  }c;
  (2) struct
  {
  int a;
  }c;
  (3)typedef struct name
  {int a;
  int b;
  }c;
  上述三个例子中c 分别是 结构体变量,结构体变量,结构体类型名。一和二的不同是 第二种c是无名的变量。因此是独一无二的一个该类型。要想定义一个指针。可以在定义结构体的时候同时定义两个变量,一个 c *p; p=&c;此时便指向了c变量。这个时候用强制类型是不行的。
  此外还要注意对结构体成员的访问,(*p).a;或者p->a;
  联合
  union name
  {
  int a;
  char b;
  }change;
  共用体的结构定义和结构体的定义是一样的,只是内存分配的形式不一样,共用体是占用数据类型最大的类型的内存,
  如上面的例子,可知该共用体的内存是4个字节。
  因此对共用体赋值的时候会出现麻烦。例如:
  change.a=0;
  change.b=-7;
  cout<<change.a;
  此时的结果不是-7;共用体的系统内存非配是底地址靠齐,因此-7是占一个字节,最高位是符号位,但是对于整形的数来说并不是符号位,所以高位都是0,结果是256-7=249;所以对共用体的赋值一定要注意。
  枚举
  enum day{mon,tue,wed,thr};
  枚举类型,day是类型,mon 等是枚举值,系统默认从0开始赋值,后一个事前一个加一。提示枚举值还可以自己来对其赋值。
  如:mon=4,tue,wed=7,thr
  此时枚举值是4 5 7 8
  可以定义枚举变量 day a;
  a=0;这样赋值是不对的,因为枚举类型的变量赋值只能是枚举值的值,因此a=mon,这个时候就是正确的。
  还有,枚举类型的内存, 都是4个字节。

阅读更多
文章标签: struct c
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

关闭
关闭
关闭