0

0

c# 枚举 enum 的用法

幻夢星雲

幻夢星雲

发布时间:2025-12-31 11:35:02

|

274人浏览过

|

来源于php中文网

原创

实用安全的enum需显式指定底层类型(如byte)和值,避免默认递增;字符串转换须处理大小写、空值;Flags枚举值必须为2的幂;API中慎用enum序列化,优先DTO映射。

c# 枚举 enum 的用法

怎么定义一个实用又安全的 enum

直接用 enum 关键字就能定义,但关键在“底层类型”和“值分配”是否合理。默认是 int,从 0 开始递增,看似省事,但容易埋坑——比如你后续想加新项插在中间,所有后续值都会偏移。

  • 显式赋值更可控:enum HttpStatusCode { OK = 200, BadRequest = 400, NotFound = 404 }
  • 小范围取值(如状态码 0–255)优先选 byte:节省内存,且编译器会强制检查越界 —— enum Status : byte { Idle = 0, Running = 1, Error = 255 }
  • 避免跳着赋值(如 A = 1, B = 100, C = 101),除非真有语义需求;否则别人读代码时容易误判连续性

字符串 ↔ 枚举转换时最常踩的三个坑

ToString()Enum.TryParse() 看似简单,但实际项目里 70% 的枚举解析失败都源于大小写、空格或无效输入没兜住。

  • ToString() 返回的是成员名,不是描述文本(比如 DayOfWeek.Monday.ToString()"Monday",不是 "星期一"
  • Enum.TryParse("monday", out DayOfWeek d) 默认**区分大小写**,会失败;必须加 true 参数:Enum.TryParse("monday", true, out d)
  • 传入空字符串或 null 给 TryParse 会返回 false,但不会抛异常;务必检查返回值,别只依赖 out 变量

[Flags] 位枚举不是“加个特性就完事”

加了 [Flags] 特性后,ToString() 才能输出 "Read, Write" 这种组合形式,但前提是你的值必须是 2 的幂次(1, 2, 4, 8…),否则 HasFlag() 行为不可靠。

95Shop仿醉品商城
95Shop仿醉品商城

95Shop可以免费下载使用,是一款仿醉品商城网店系统,内置SEO优化,具有模块丰富、管理简洁直观,操作易用等特点,系统功能完整,运行速度较快,采用ASP.NET(C#)技术开发,配合SQL Serve2000数据库存储数据,运行环境为微软ASP.NET 2.0。95Shop官方网站定期开发新功能和维护升级。可以放心使用! 安装运行方法 1、下载软件压缩包; 2、将下载的软件压缩包解压缩,得到we

下载
[Flags]
public enum Permissions
{
    None = 0,
    Read = 1,
    Write = 2,
    Execute = 4,
    All = Read | Write | Execute // ✅ 正确组合
}

Permissions p = Permissions.Read | Permissions.Write;
Console.WriteLine(p.ToString()); // 输出: "Read, Write"
Console.WriteLine(p.HasFlag(Permissions.Write)); // true
  • 错误示范:Read = 1, Write = 3 —— 3 不是 2 的幂,HasFlag 可能误判
  • 检查权限推荐用 (p & Permissions.Write) == Permissions.Write,比 HasFlag 更明确、性能略高
  • None = 0 必须存在,且不能和其他值做按位或(否则逻辑混乱)

为什么 enum 不该出现在 public API 的 JSON 序列化里

ASP.NET Core 默认把 enum 序列化成整数(如 { "status": 1 }),前端根本看不懂;而设成字符串(JsonSerializerOptions.Converters.Add(new JsonStringEnumConverter()))又可能破坏老客户端兼容性。

  • 对外暴露的 API,建议用 string 字段 + 数据验证,或封装一层 DTO 映射到语义清晰的字符串(如 "active", "pending"
  • 内部模块间传递可用 enum,但跨服务/跨语言场景,整数序列化风险高(不同语言 enum 值可能不一致)
  • 如果坚持用 enum 序列化,务必在 Swagger 或 OpenAPI 文档中用 [EnumMember] 显式标注每个值的字符串表示,否则文档和实际行为对不上
枚举本身很简单,但真正难的是在团队协作、长期迭代、跨系统交互中保持它的语义稳定性和可解释性。很多人只记得“用名字代替数字”,却忘了名字一旦发布,改起来比数据库字段还麻烦。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

402

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

528

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

306

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

312

2023.08.02

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

229

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

433

2024.03.01

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

184

2023.10.18

vlookup函数使用大全
vlookup函数使用大全

本专题整合了vlookup函数相关 教程,阅读专题下面的文章了解更多详细内容。

26

2025.12.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.1万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号