C++枚举类型Enum总结
C++的 enum 工具提供了一种创造符号变量的方式,可以替代 const。
enum spectrum{red,orange,yellow,green,blue,violet,indigo,ultraviolet};
spectrum称为枚举,其中的符号常量称之为枚举量。
-
可以用枚举名来声明这种类型的变量:
//使用枚举名声明这种类型的变量 spectrum band;
-
枚举变量赋值
band = blue;//valid band=2000;//invalid
-
对于枚举,只定义了赋值运算符。(无算数运算符)
band = orange; ++band;//invalid band = orange+red;//not valid
因为没有为枚举定义运算符+,但用于算术表达式时,red 和 orange 被转化成 1+0,但是其类型为 int,不可以赋值给 band。
-
枚举量是整形,可被提升为 int 类型,但是 int 类型不能自动转换为枚举类型
int color=blue;
band=3;//invalid
color = 3+red;
-
如果 int 值有效,则可以通过强制类型转换,将它赋给枚举变量, //如果尝试对一个不恰当的值做强制类型转换,不会出错, //但是不能依赖得到的结果
band = spectrum(3); band = spectrum(400003);//40003
-
可以创建多个值相同的枚举量(可将 int、long 甚至 long long 类型的值赋给枚举量)
enum bits{zero,null=0,one,numero_uno=1};
-
枚举的取值范围
上限:先找到枚举量的最大值,上限为大于这个值得最小的2的幂减去 1。
下限:先找到枚举量的最小值,如果不小于 0,下限为 0.否则,采用同样的方式,例如枚举量最小值为-6,则下限为-7.
-
存储空间
由编译器决定,取值范围较小的枚举,使用一个字节或者更少的空间,包含 long 类型的枚举,则使用 4 个字节。
作用域内枚举(C++11)
传统的枚举存在一些问题,例如两个枚举定义中的枚举量可能冲突。
例如:
enum egg {Small,Medium Large,Jumbo};
enum t_shirt{Small,Medium,Large,Xlarge};
这将导致无法通过编译。因为 eggs 和 t_shirt 位于同样的作用域。C++11提供一种新的枚举,其枚举量的作用域为类。
enum class egg{Small,Medium Large,Jumbo};
enum class t_shirt{Small,Medium,Large,Xlarge};
也可以使用关键字 struct代替 class。无论哪种方式,都需要使用枚举名来限定枚举量:
egg choice = egg::Large;
t_shirt Flyod = t_shirt::Medium;
- C++11提高了作用域内枚举的类型安全:
enum egg_old{Small,Medium Large,Jumbo};
enum class t_shirt{Small,Medium,Large,Xlarge};
egg_old one = Medium;
t_shirt rolf = t_shirt::Large;
int king = one; //one隐式转换成 int
int ring = rolf; //错误
if(king<Jumbo)
cout<<"Jumbo converted to int before coomparision.\n";
if(king<t_shirt::Large) //not allow
cout<<"Not allowed:< not defined for scoped enum.\n";
但是,必要时可进行显示类型转换:
int Frodo = int(t_shirt::Small);
- 枚举用某种底层整型类型实现,因此包含枚举的结构类型随系统而变。对于作用域内枚举,C++11 作用域内的枚举底层整型类型默认为 int,也可以改变:
enum class::short pizza{Small,Medium,Large,Xlarge};