目录
继结构体后今天给大家带来两种新的自定义类型——枚举和联合
1.枚举类型
枚举顾名思义就是一一列举。 把可能的取值一一列举出来,定义成一个类型然后使用
1.1 枚举类型的定义
enum Day//星期
{
Mon,
Tues,
Wed,
Thur,
Fri,
Sat,
Sun
};
enum Sex//性别
{
MALE,
FEMALE,
SECRET
};
enum Color//颜色
{
RED,
GREEN,
BLUE
};
以上三个表示的都是枚举类型,而{}内容表示的是枚举类型可能的取值,也叫做枚举常量,对于该枚举常量的值,一般是默认从0开始,一次递增1,当然在定义的时候也可以赋初值。
对于赋值后该内部的值的分布是,在该赋值上面的数从0开始依次递增1,在该下面的数从这个数的值开始一次往下按1递增。
这里我给大家用展示一下:
enum Day//星期
{
Mon,
Tues,
Wed,
Thur=5,
Fri,
Sat,
Sun
};
int main()
{
printf("%d\n", Mon);
printf("%d\n", Tues);
printf("%d\n", Wed);
printf("%d\n", Thur);
printf("%d\n", Fri);
printf("%d\n", Sat);
printf("%d\n", Sun);
return 0;
}
结果是:
1.2 使用枚举类型的优势
枚举的优点:
1.
增加代码的可读性和可维护性
2.
和
#define
定义的标识符比较枚举有类型检查,更加严谨。
3.
防止了命名污染(封装)
4.
便于调试
5.
使用方便,一次可以定义多个常量
2. 联合体类型
2.1联合体类型的定义
联合也是一种特殊的自定义类型,这种类型定义的变量也包含一系列的成员,特征是这些成员公用同一块空间(所以联合也叫共用体)。
union Un
{
char c;
int i;
};
联合体具有以下特点:
联合的成员是共用同一块内存空间的,这样一个联合变量的大小,至少是最大成员的大小(因为联
合至少得有能力保存最大的那个成员)。由于联合体的特点,这里我们就可以利用联合体的特点来进行大小端的判断。
代码如下:
union un
{
int i ;
char j;
};
int main()
{
union un n;
n.i = 1;
if (n.j == 1)
{
printf("小端");
}
else
printf("大端");
return 0;
}
在vs2019的结果如下:
2.2 联合体大小的计算
联合体大小遵循以下规则:
1.联合的大小至少是最大成员的大小。
2.当最大成员大小不是最大对齐数的整数倍的时候,就要对齐到最大对齐数的整数倍。
根据这个特点我们就可以对上面的联合体进行大小判断:
(由于在结构体已经给大家介绍过一些规则,这里就不再说明)
union un
{
char j;
int i ;
};
int main()
{
printf("%d", sizeof(union un));
return 0;
}
由这里可以得到该联合体的大小是: