2.枚举的优点
为什么使用枚举?
我们可以使用 #define 定义常量,为什么非要使用枚举?
枚举的优点:
- 增加代码的可读性和可维护性
- 和#define定义的标识符比较枚举有类型检查,更加严谨。
- 防止了命名污染(封装)
- 便于调试
- 使用方便,一次可以定义多个常量
3.枚举的使用
enum Color//颜色 { RED=1, GREEN=2, BLUE=4 }; enum Color clr = GREEN; //只能拿枚举常量给枚举变量赋值,才不会出现类型的差异。 clr = 5; //不能这样赋值
三、联合(共用体)
1.联合类型的定义
联合也是一种特殊的自定义类型。
这种类型定义的变量也包含一系列的成员,特征是这些成员共用同一块空间(所以联合也叫共体)。
比如:
//联合类型的声明 union Un { char c; int i; }; //联合变量的定义 union Un un; //计算联合体变量的大小 printf("%d\n", sizeof(un)); //大小为4,计算规则下面细说
2.联合的特点
联合的成员是共用同一块内存空间的,这样一个联合变量的大小,至少是最大成员的大小(因为联合至少得有能力保存最大的那个成员)。
union Un { int i; char c; }; union Un un; // 下面输出的结果是一样的吗? printf("%d\n", &(un.i)); printf("%d\n", &(un.c)); //下面输出的结果是什么? un.i = 0x11223344; un.c = 0x55; printf("%x\n", un.i); //16进制打印
可以看出它们的所占用的首地址是一样的。
如果先存放 0x11223344 ,因为是小端存储,所以在内存中存放的顺序应该是 44 33 22 11 ,再存放char型的55,就会修改44,得到 55 33 22 11,也就是数据11223355。(如果对大小端有疑惑,可以翻看往期博文)
3.联合大小的计算
联合的大小至少是最大成员的大小。
当最大成员大小不是最大对齐数的整数倍的时候,就要对齐到最大对齐数的整数倍。
比如:
union Un1 { char c[5]; int i; }; union Un2 { short c[7]; int i; }; //下面输出的结果是什么? printf("%d\n", sizeof(union Un1)); printf("%d\n", sizeof(union Un2));
解析:
union Un1 { char c[5]; //占用5个比特位,对齐数为1 int i; //占用4个比特位,对齐数为4 最大对齐数为4 }; //该联合体最小为5,因为不是最大对齐数的倍数,所以为8 union Un2 { short c[7]; //占用14个比特位,对齐数为2 int i; //占用4个比特位,对齐数为4 最大对齐数为4 }; //该联合体最小为14,因为不是最大对齐数的倍数,所以为16 int main() { printf("%d\n", sizeof(union Un1)); printf("%d\n", sizeof(union Un2)); return 0; }
关于结构体我们已经有了一个比较深入的了解,下期我们就来做个通讯录吧,算是对所学知识的一种总结运用了。