| ylbtech-Docs-.NET-C#-指南-语言参考-关键字-值类型:enum |
| 1.返回顶部 |
enum(C# 参考)
enum 关键字用于声明枚举,一种包含一组被称为枚举数列表的已命名常数的不同类型。
通常最好是直接在命名空间内定义枚举,以便命名空间中的所有类都可以同样方便地访问它。 但是,也可能会在类或结构中嵌套枚举。
默认情况下,第一个枚举数具有值 0,并且每个连续枚举数的值将增加 1。 例如,在以下枚举中, Sat 的值为 0, Sun 的值为 1, Mon 的值为 2,依次类推。
enum Day {Sat, Sun, Mon, Tue, Wed, Thu, Fri};
枚举数可以使用初始值设定项来替代默认值,如下面的示例中所示。
enum Day {Sat=1, Sun, Mon, Tue, Wed, Thu, Fri};
在此枚举中,强制元素的序列从 1 开始,而不是 0。 但建议包括一个值为 0 的常量。 有关详细信息,请参阅枚举类型。
每个枚举类型都有一个可以为任意整型数值类型的基础类型。 char 类型不能为枚举的基础类型。 枚举元素的默认基础类型是 int。若要声明另一整型的枚举(如 byte),则请在后跟该类型的标识符后使用冒号,如以下示例所示。
enum Day : byte {Sat=1, Sun, Mon, Tue, Wed, Thu, Fri};
枚举类型的变量可在基本类型范围内分配到任何值;这些值不限于已命名常数。
enum E 的默认值是由表达式 (E)0生成的值。
备注
枚举数名称中不能含有空格。
基础类型指定为每个枚举数分配多少存储空间。 但要将 enum 类型转换为整型,则必须使用显示转换。 例如,以下语句通过使用转换将 Sun 转换为 ,从而将枚举数 赋值为 enum int int类型的变量。
int x = (int)Day.Sun;
当你将 System.FlagsAttribute 应用到包含可与按位 OR 运算组合的元素的枚举中时,该特性与某些工具一起使用时会影响 enum 的行为。 当你使用工具(如 Console 类方法和表达式计算器)时,你可以注意到这些更改。 (请参阅第三个示例。)
可靠编程
正如任何常量一样,对枚举的各项值的所有引用在编译时都会转换为数字参数。 这可能会造成如常量中所述的潜在版本问题。
将其他值分配到枚举的新版本,或者在新版本中更改枚举成员的值,会导致出现相关源代码问题。 通常在 switch 语句中使用枚举值。 如果已将其他元素添加到 enum 类型,则 switch 语句的默认部分可被意外地选中。
如果其他开发人员使用你的代码,则在将新元素添加到任何 enum 类型时应提供有关他们的代码应该如何响应的准则。
示例
在下面的示例中,已声明枚举 Day。 已将两个枚举数显式转换为整数,并赋值为整数变量。
public class EnumTest { enum Day { Sun, Mon, Tue, Wed, Thu, Fri, Sat }; static void Main() { int x = (int)Day.Sun; int y = (int)Day.Fri; Console.WriteLine("Sun = {0}", x); Console.WriteLine("Fri = {0}", y); } } /* Output: Sun = 0 Fri = 5 */
示例
以下示例中,使用基类型选项来声明其成员是 enum 类型的 long。 请注意,即使该枚举的基础类型是 long,仍然需通过使用转换将枚举成员显式转换为类型 long 。
public class EnumTest2 { enum Range : long { Max = 2147483648L, Min = 255L }; static void Main() { long x = (long)Range.Max; long y = (long)Range.Min; Console.WriteLine("Max = {0}", x); Console.WriteLine("Min = {0}", y); } } /* Output: Max = 2147483648 Min = 255 */
示例
下面的代码示例说明了 System.FlagsAttribute 声明中 enum 特性的使用和作用。
// Add the attribute Flags or FlagsAttribute. [Flags] public enum CarOptions { // The flag for SunRoof is 0001. SunRoof = 0x01, // The flag for Spoiler is 0010. Spoiler = 0x02, // The flag for FogLights is 0100. FogLights = 0x04, // The flag for TintedWindows is 1000. TintedWindows = 0x08, } class FlagTest { static void Main() { // The bitwise OR of 0001 and 0100 is 0101. CarOptions options = CarOptions.SunRoof | CarOptions.FogLights; // Because the Flags attribute is specified, Console.WriteLine displays // the name of each enum element that corresponds to a flag that has // the value 1 in variable options. Console.WriteLine(options); // The integer value of 0101 is 5. Console.WriteLine((int)options); } } /* Output: SunRoof, FogLights 5 */
注释
如果删除 Flags,则示例将显示以下值:
5
5
C# 语言规范
有关详细信息,请参阅 C# 语言规范。 该语言规范是 C# 语法和用法的权威资料。
请参阅
| 2.返回顶部 |
| 3.返回顶部 |
| 4.返回顶部 |
| 5.返回顶部 |
| 6.返回顶部 |
| 作者:ylbtech 出处:http://ylbtech.cnblogs.com/ 本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。 |