C++中enum的用法是什么?
1个回答
展开全部
1、枚举enum的用途浅例
写程序时,我们常常需要为某个对象关联一组可选的属性.例如,学生的成绩分A,B,C,D等,天气分
sunny, cloudy, rainy等等。更常见的,打开一个文件可能有三种状态:input, output和append. 典型
做法是,对应定义3个常数,即:const int input = 1; const int output = 2; const int append =
3; 然后,调用以下函数:bool open_file(string file_name, int open_mode); 比如,open_file("Phenix_and_the_Crane", append);这种做法比较简单,但存在许多缺点,主要的一点就是
无法限制传递给open_file函数的第2个参数的取值范围,只要传递int类型的值都是合法的。当然,这样
的情况下的应对措施就是在open_file函数内部判断第二个参数的取值,只有在1,2,3范围内才处理。
使用枚举能在一定程度上减轻这种尴尬,它不但能实现类似于之前定义三个常量的功能,还能够将这三
个值组合起来成为独一无二的组。例如:enum open_modes {input = 1, output, append}; 以上定义了
open_modes为枚举类型enumeration type。每一个命名了的枚举都是唯一的类型,是一个类型标示器
type specifier。例如,我们可以重新写一个open_file函数: bool open_file(string file_name,
open_modes om); 在open_modes枚举中,input, output, append称为枚举子enumerator, 它们限定了
open_modes定义的对象的取值范围。这个时候,调用open_file函数和之前的方法还是一模一样:
open_file("Phenix_and_the_Crane", append);
但是,如果传递给open_file的第二个参数不是open_modes枚举类型值的话那么编译器就会识别出错误;
就算该参数取值等价于input, output, append中的某个,
也一样会出错哦!例如:open_file("Phenix_and_the_Crane", 1);
2、注意事项
(1. 枚举中每个成员(标识符)结束符是",",不是";", 最后一个成员可省略 ","。
(2. 初始化时可以赋负数, 以后的标识符仍依次加1。
(3. 枚举变量只能取枚举说明结构中的某个标识符常量。
(4.在外部,我们可以对枚举变量进行赋值,不过,得要进行类型转换。
如果我们不进行类型轮换,即如下所示进行赋值: x = 3;是不允许的,如果对X进行赋值,只能对3进行类型转换.即:x = (string)3
那么这样就对了.
如果给x赋的不是一个整形的数,而是一个字符型的,如:x = (string)’a’;那么这时候x的值并不是字符’a’,而是’a’的ASCII码,我们知道,在枚举类型中,各常量的值只能是整形的,所以在对上例会自的将’a’转换成一个整数值.从内存的角度来看来话,其实C/C++中整形和字符型的变量是一样的,它们之间可以互相转换.
写程序时,我们常常需要为某个对象关联一组可选的属性.例如,学生的成绩分A,B,C,D等,天气分
sunny, cloudy, rainy等等。更常见的,打开一个文件可能有三种状态:input, output和append. 典型
做法是,对应定义3个常数,即:const int input = 1; const int output = 2; const int append =
3; 然后,调用以下函数:bool open_file(string file_name, int open_mode); 比如,open_file("Phenix_and_the_Crane", append);这种做法比较简单,但存在许多缺点,主要的一点就是
无法限制传递给open_file函数的第2个参数的取值范围,只要传递int类型的值都是合法的。当然,这样
的情况下的应对措施就是在open_file函数内部判断第二个参数的取值,只有在1,2,3范围内才处理。
使用枚举能在一定程度上减轻这种尴尬,它不但能实现类似于之前定义三个常量的功能,还能够将这三
个值组合起来成为独一无二的组。例如:enum open_modes {input = 1, output, append}; 以上定义了
open_modes为枚举类型enumeration type。每一个命名了的枚举都是唯一的类型,是一个类型标示器
type specifier。例如,我们可以重新写一个open_file函数: bool open_file(string file_name,
open_modes om); 在open_modes枚举中,input, output, append称为枚举子enumerator, 它们限定了
open_modes定义的对象的取值范围。这个时候,调用open_file函数和之前的方法还是一模一样:
open_file("Phenix_and_the_Crane", append);
但是,如果传递给open_file的第二个参数不是open_modes枚举类型值的话那么编译器就会识别出错误;
就算该参数取值等价于input, output, append中的某个,
也一样会出错哦!例如:open_file("Phenix_and_the_Crane", 1);
2、注意事项
(1. 枚举中每个成员(标识符)结束符是",",不是";", 最后一个成员可省略 ","。
(2. 初始化时可以赋负数, 以后的标识符仍依次加1。
(3. 枚举变量只能取枚举说明结构中的某个标识符常量。
(4.在外部,我们可以对枚举变量进行赋值,不过,得要进行类型转换。
如果我们不进行类型轮换,即如下所示进行赋值: x = 3;是不允许的,如果对X进行赋值,只能对3进行类型转换.即:x = (string)3
那么这样就对了.
如果给x赋的不是一个整形的数,而是一个字符型的,如:x = (string)’a’;那么这时候x的值并不是字符’a’,而是’a’的ASCII码,我们知道,在枚举类型中,各常量的值只能是整形的,所以在对上例会自的将’a’转换成一个整数值.从内存的角度来看来话,其实C/C++中整形和字符型的变量是一样的,它们之间可以互相转换.
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询