C# 枚举类型

简介:     枚举类型是一种的值类型,它用于声明一组命名的常数。与字符串相比,用枚举的好处就是限定了变量的取值范围,程序处理起来更方便。    (1)枚举的声明访问修辞符 enum 枚举名:基础类型 { 枚举成员 }    基础类型必须能够表示该枚举中定义的所有枚举数值。枚举声明可以显式地声明 byte、sbyte、short、ushort、int、ui

    枚举类型是一种的值类型,它用于声明一组命名的常数。与字符串相比,用枚举的好处就是限定了变量的取值范围,程序处理起来更方便。
   (1)
枚举的声明

访问修辞符 enum 枚举名:基础类型
    {
        枚举成员
    }
     基础类型必须能够表示该枚举中定义的所有枚举数值。枚举声明可以显式地声明 byte sbyte short ushort int uint long ulong 类型作为对应的基础类型。没有显式地声明基础类型的枚举声明意味着所对应的基础类型是 int
    (2)
枚举成员
        
每个枚举成员均具有相关联的常数值。此值的类型就是枚举的基础类型。每个枚举成员的常数值必须在该枚举的基础类型的范围之内。
    
示例 :
  public enum TimeofDay:uint
        {
            Morning=-3,
            Afternoon=-2,
            Evening=-1
         }   
    产生编译时错误,原因是常数值 -1 -2 –3 不在基础整型 uint 的范围内。
    (3)
枚举成员默认值          
       
在枚举类型中声明的第一个枚举成员它的默值为零。  
       
以后的枚举成员值是将前一个枚举成员(按照文本顺序)的值加 1 得到的。这样增加后的值必须在该基础类型可表示的值的范围内;否则,会出现编译时错误。  
   
示例 :
  public enum TimeofDay:uint
        {
            Morning,
            Afternoon,
            Evening
         }   
    Morning 的值为 0,Afternoon 的值为 1,Evening 的值为 2
    (4)
为枚举成员显示赋值
        
允许多个枚举成员有相同的值 .
        
没有显示赋值的枚举成员的值,总是前一个枚举成员的值 +1.
      
示例     
 public enum Number
        {
            a=1,
            b,
            c=1,
            d
        }
        b 的值为 2,d 的值为 2.
    
注意:以上枚举值都不能超过它的基础类型范围。否则会报错 .
    (5)
枚举类型与基础类型的转换
     
基础类型不能隐式转换为枚举类型
    
枚举类型也不能隐式转换为基础类型
    
示例 :
  public enum Number
    {
        a,
        b,
        c,
        d
    }

    class Test
    {
        public static void Main()
        {
            inti=Number.a;//错误,要强制类型转换(int)Number.a
            Numbern;
            n=2           //错误,要强制类型转换(Number)2
        }
    }

    (6)使用枚举类型

 <数据类型> 变量名= <数据类型>.枚举成员

相关文章
|
8月前
|
C#
C#数据类型之枚举类型
C#数据类型之枚举类型
211 0
|
5月前
|
C#
C# 面向对象编程(三)——接口/枚举类型/泛型
C# 面向对象编程(三)——接口/枚举类型/泛型
44 0
|
PHP C# 索引
C#(十)之枚举类型与结构体
枚举类型基本用法;官方给的C#结构体的特点、基本用法。
169 0
C#(十)之枚举类型与结构体
|
C#
C# 给枚举类型增加一个描述特性
前言 相信很多人对枚举并不陌生,枚举可以很方便和直观的管理一组特定值。如果我们在页面上直接输出我们希望匹配的汉语意思或则其他满足我们需求的语句就更好了,当然,通常小伙伴们都会再页面上if(enum==1) “我是一个枚举”或者switch(enum)这种方式解决。
1055 0
C#枚举类型遍历案例
using System; using System.Collections.Generic; using System.Linq; using System.
1159 0