导读:本期聚焦于小伙伴创作的《C#如何定义枚举?C#定义枚举完整教程与代码实例》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《C#如何定义枚举?C#定义枚举完整教程与代码实例》有用,将其分享出去将是对创作者最好的鼓励。

在C#开发中,枚举是一种特殊的值类型,用于定义一组具有命名常量的集合,能够替代魔法数字,让代码逻辑更清晰,取值更规范。枚举常用于表示固定的状态、类型、选项等场景,比如订单状态、用户角色、颜色类型等。

C#如何定义枚举?C#定义枚举完整教程与代码实例

C#枚举的基础定义语法

定义C#枚举使用enum关键字,基础语法结构如下:

// 基础枚举定义,默认底层类型是int
enum OrderStatus
{
    // 第一个成员默认值为0,后续成员依次递增1
    Pending,    // 待处理,值为0
    Processing, // 处理中,值为1
    Shipped,    // 已发货,值为2
    Delivered   // 已送达,值为3
}

枚举的默认底层类型是int,也可以显式指定其他整数类型作为底层类型,支持的类型包括bytesbyteshortushortintuintlongulong

// 指定底层类型为byte的枚举
enum ColorType : byte
{
    Red,    // 0
    Green,  // 1
    Blue    // 2
}

带自定义初始值的枚举定义

可以手动为枚举成员指定初始值,未指定初始值的成员会在前一个成员值的基础上递增1。

enum ErrorCode
{
    Success = 0,       // 成功,值为0
    ParamError = 1001, // 参数错误,值为1001
    AuthError = 1002,  // 权限错误,值为1002
    ServerError = 2001 // 服务错误,值为2001
}

带Flags特性的枚举定义

如果需要枚举可以同时表示多个值,可以使用Flags特性,此时每个成员的值建议设置为2的幂次,方便进行位运算。

[Flags]
enum Permission
{
    None = 0,      // 无权限,0
    Read = 1,      // 读权限,1
    Write = 2,     // 写权限,2
    Delete = 4,    // 删除权限,4
    All = Read | Write | Delete // 所有权限,7
}

枚举的常见使用示例

枚举变量的声明与赋值

class Program
{
    static void Main()
    {
        // 声明枚举变量并赋值
        OrderStatus status = OrderStatus.Processing;
        Console.WriteLine(status); // 输出:Processing
        
        // 带Flags特性的枚举赋值
        Permission perm = Permission.Read | Permission.Write;
        Console.WriteLine(perm); // 输出:Read, Write
    }
}

枚举与整数之间的转换

枚举和底层整数类型之间可以进行显式转换:

// 整数转枚举
int statusValue = 2;
OrderStatus status = (OrderStatus)statusValue;
Console.WriteLine(status); // 输出:Shipped

// 枚举转整数
OrderStatus currentStatus = OrderStatus.Delivered;
int intValue = (int)currentStatus;
Console.WriteLine(intValue); // 输出:3

枚举与字符串之间的转换

// 字符串转枚举
string statusStr = "Pending";
OrderStatus parsedStatus = (OrderStatus)Enum.Parse(typeof(OrderStatus), statusStr);
Console.WriteLine(parsedStatus); // 输出:Pending

// 枚举转字符串
OrderStatus status = OrderStatus.Shipped;
string statusString = status.ToString();
Console.WriteLine(statusString); // 输出:Shipped

// 安全转换,避免转换失败抛出异常
if (Enum.TryParse<OrderStatus>("Processing", out OrderStatus result))
{
    Console.WriteLine(result); // 输出:Processing
}

枚举使用的注意事项

  • 枚举成员的名称建议使用 Pascal 命名法,语义清晰,避免使用无意义的名称。
  • 进行枚举转换时,如果值不在枚举定义的范围内,不会报错但会得到无意义的枚举值,建议转换前先判断值是否有效。
  • 使用Flags特性时,建议显式定义None = 0的成员,方便表示空状态。
  • 不要给枚举成员赋值为负数,除非有特殊业务需求,避免位运算时出现逻辑问题。

可以通过以下方法判断某个值是否是枚举的有效成员:

int testValue = 5;
bool isValid = Enum.IsDefined(typeof(OrderStatus), testValue);
Console.WriteLine(isValid); // 输出:False,5不在OrderStatus的有效值中

string testStr = "Shipped";
bool isStrValid = Enum.IsDefined(typeof(OrderStatus), testStr);
Console.WriteLine(isStrValid); // 输出:True,Shipped是有效成员

C#enum枚举定义枚举使用方法修改时间:2026-07-02 07:48:28

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。