前言
继结构体后今天给大家带来两种新的自定义类型——枚举和联合
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; }
由这里可以得到该联合体的大小是: