🌱2.枚举
🍀🍀 2.1枚举概述
🌼🌼🌼2.1.1枚举概念
枚举:就是一一列举。
枚举常量:{ }中的内容是枚举类型的可能取值,就叫枚举常量 。
枚举常量都是有值的,默认从0开始,一次递增1,当然在定义的时候也可以赋初值。
比如我们现实生活中:
一周的星期一到星期日是有限的7天,可以一一列举。
性别有:男、女、保密,也可以一一列举。
月份有12个月,也可以一一列举
🌼🌼🌼2.1.2枚举的声明与使用
enum Color//颜色 { RED, GREEN, BLUE }; int main() { printf("%d ", RED); //0 printf("%d ", GREEN); //1 printf("%d ", BLUE); //2 return 0; }
以上定义的 enum Day
, enum Sex
, enum Color
都是枚举类型。
🌱亦可以自己对枚举初始化:
enum Color//颜色 { RED=5, GREEN=8, BLUE };
🌱枚举类型的使用
enum Color//颜色 { RED=1, GREEN=2, BLUE=4 }; enum Color clr = GREEN;//只能拿枚举常量给枚举变量赋值,才不会出现类型的差异。 clr = 5; //这样不行
🍀🍀 2.2枚举大小计算
枚举变量的大小,即枚举类型所占内存的大小,枚举类型变量都占4字节。
enum A { QSW, BSW, CWS }a; int main() { printf("%d\n", sizeof(a)); return 0; }
🍀🍀 2.3枚举与宏的区别
使用枚举定义的枚举常量是有类型的,为枚举类型,而使用#define宏是替换,并没有枚举类型这种性质。
🌱 枚举的优点
增加代码的可读性和可维护性
和#define定义的标识符比较枚举有类型检查,更加严谨。
防止了命名污染(封装)
便于调试
使用方便,一次可以定义多个常量
🌱3.联合体
🍀🍀 3.1联合体概述
🌼🌼🌼3.1.1联合体概念
联合:也是一种特殊的自定义类型
这种类型定义的变量也包含一系列的成员,特征是这些成员公用同一块空间(所以联合也叫共用体)。
//联合类型的声明 union Un { char c; int i; }; //联合变量的定义 union Un un; //计算连个变量的大小
🌼🌼🌼3.1.2联合体的声明与使用
//联合类型的声明 union Un { char c; int i; }; //联合变量的定义 union Un un; //计算连个变量的大小 printf("%d\n", sizeof(un));
🌼分析:打印的结果是4个字节
🌼联合的成员是共用同一块内存空间的,这样一个联合变量的大小,至少是最大成员的大小
(因为联合至少得有能力保存最大的那个成员)。
union Un { char c; int i; }; union Un u; int main() { printf("%p ", &u); printf("%p ", &(u.c)); printf("%p ", &(u.i)); return 0; }
🌼🌼🌼3.1.3联合体判断大小端存储
🌱关于大小端:
内存中存储这两个字节有两种方法:
- 小端字节序:将低序字节存储在起始地址。
- 大端字节序:将高序字节存储在起始地址。
🌱方法一:未使用联合体
int main() { int a = 1; char* pc = (char*)&a;//强制类型转化取的是低位的数据 if (*pc == 1) { printf("小端"); } else printf("大端"); return 0; }
🌱方法二:使用联合体
int main() { union U { char c; int i; }; u.i = 1; if (u.c == 1) { printf("小端"); } else printf("大端"); return 0; }
🍀🍀 3.2联合体大小计算
- 联合的大小至少是最大成员的大小。
- 当最大成员大小不是最大对齐数的整数倍的时候,就要对齐到最大对齐数的整数倍。
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));
🌱分析
- 对于Un1来说,其对齐数是4,而char[5]占据了5个字节,超过了4,因此结果为8
- Un2来说,其对齐数是4,而short[7]占据了14个字节,超过了12,因此结果为16