C#枚举(一)使用总结以及扩展类分享
0.介绍
枚举是一组命名常量,其基础类型为任意整型。 如果没有显式声明基础类型, 则为Int32
在实际开发过程中,枚举的使用可以让代码更加清晰且优雅。
最近在对枚举的使用进行了一些总结与整理,也发现了一些很有意思的知识盲区。
接下来先简单为大家介绍枚举在开发过程中的常用内容以及扩展类的分享。如果喜欢直接看代码的可以查看最后的样例源码。
1. 参考资料
官方Doc https://docs.microsoft.com/zh-cn/dotnet/api/system.enum?view=net-5.0
博客 https://www.cnblogs.com/kissdodog/archive/2013/01/16/2863515.html
博客 https://www.cnblogs.com/willick/p/csharp-enum-superior-tactics.html
2.核心内容
枚举的使用心得
0.枚举数值在开发过程中一旦确定不允许更改(除非必要 )
1.在定义枚举的时候要设置0值,且不作为有效的业务值。(不作为有效值的原因是枚举的初始化值为零,在没有正确赋值的情况下,已经有默认值可能会造成困扰,所以直接不使用0作为业务有效值,可以省去不必要的麻烦,这半点纯属个人建议~)
这一点官方文档也有“最佳做法”的建议。
如果未定义值为0的枚举成员,则考虑创建 None 枚举常数。 默认情况下,由公共语言运行时将用于枚举的内存初始化为零。 因此,如果未定义值为零的常量,则在创建枚举时将包含非法值。
2.在前后端交互过程中,如果后端接收的对象中包含枚举的话,需要将枚举属性定义成可空枚举,否则前端数据有可能(前端属性值在后端的枚举值中匹配不上时)无法传输到后端。
3.数据库保存枚举值而非枚举属性字符串
虽然保存枚举属性字符串会更加直观,但是不利于后续枚举字符串重命名,且字符串长度限制也制约着枚举的命名...
枚举的基本用法
定义枚举
枚举并不显式从继承 Enum ; 继承关系由编译器隐式处理
// 枚举YesOrNo
public enum YesOrNo
{
[Description("")]
None = 0,
[Description("是")]
Yes = 1,
[Description("否")]
No = 2
}
// 枚举YesOrNo 基础类型为byte
public enum YesOrNo_Byte : byte
{
[Description("")]
None = 0,
[Description("是")]
Yes = 1,
[Description("否")]
No = 2
}
枚举 => 转字符串
string yesString = YesOrNo.Yes.ToString(); // Yes
枚举 => 转数字
int yesInt = (int)YesOrNo.Yes; // 1
字符串 => 枚举
YesOrNo yesOrNo_Yes = (YesOrNo)Enum.Parse(typeof(YesOrNo), "Yes"); // YesOrNo.Yes
数字 => 枚举
YesOrNo yesOrNo_No = (YesOrNo)2; // YesOrNo.No
获取所有的枚举成员
Array yesOrNos = Enum.GetValues(typeof(YesOrNo)); // [YesOrNo.None,YesOrNo.Yes,YesOrNo.No]
获取所有枚举成员的属性名
string[] yesOrNoNames = Enum.GetNames(typeof(YesOrNo)); // ["None","Yes","No"]
获取枚的举基础类型
Type typeInt = Enum.GetUnderlyingType(typeof(YesOrNo)); // System.Int32
Type typeByte = Enum.GetUnderlyingType(typeof(YesOrNo_Byte)); // System.Byte
扩展方法
字符串 => 转枚举
// GetEnum() 字符串 => 转枚举
var yesString = "Yes".GetEnum<YesOrNo>(); // YesOrNo.Yes
/// <summary>
/// 根据字符串转成指定枚举值
/// </summary>
public static T GetEnum<T>(this string enumString)
{
return (T)Enum.Parse(typeof(T), enumString);
}
枚举 => 转数字
// GetIntValue() 枚举 => 转数字
int yesInt = YesOrNo.Yes.GetIntValue(); // 1
/// <summary>
/// 获取枚举的值
/// </summary>
public static int GetIntValue(this Enum value)
{
return Convert.ToInt32(value);
}
获取枚举的描述
// GetDescription() 获取枚举的描述
var description = YesOrNo.Yes.GetDescription(); // 是
/// <summary>
/// 根据枚举获取枚举描述
/// </summary>
public static string GetDescription(this Enum value)
{
var field = value.GetType().GetField(value.ToString());
var customAttribute = Attribute.GetCustomAttribute(field, typeof(DescriptionAttribute));
if (customAttribute == null)
return value.ToString();
else
return ((DescriptionAttribute)customAttribute).Description;
}
将枚举字符串值与描述转字典
// GetEnumDescriptions() 获取枚举字符串值与描述
var dictionary = typeof(YesOrNo).GetEnumDescriptions(); // {{[None, ""]},{[Yes, 是]},{[No, 否]}}
/// <summary>
/// 获取枚举字符串值及描述值的字典
/// </summary>
public static IDictionary<string, string> GetEnumDescriptions(this Type enumType)
{
var dictionary = new Dictionary<string, string>();
foreach (Enum code in Enum.GetValues(enumType))
dictionary.Add(code.ToString(), code.GetDescription());
return dictionary;
}
将枚举值与描述转字典
// GetEnumIntDescriptions() 获取枚举值与描述
var intDictionary = typeof(YesOrNo).GetEnumIntDescriptions(); // {{[0, ""]},{[1, 是]},{[2, 否]}}
/// <summary>
/// 获取枚举值及描述值的字典
/// </summary>
public static IDictionary<int, string> GetEnumIntDescriptions(this Type enumType)
{
var dictionary = new Dictionary<int, string>();
foreach (Enum code in Enum.GetValues(enumType))
dictionary.Add(code.GetIntValue(), code.GetDescription());
return dictionary;
}
3.样例源码地址
C#枚举(一)使用总结以及扩展类分享的更多相关文章
- Java+7入门经典 - 6 扩展类与继承 Part 1/2
第6章 扩展类与继承 面向对象编程的一个重要特性: 允许基于已定义的类创建新的类; 6.1 使用已有的类 派生 derivation, 派生类 derived class, 直接子类 direct s ...
- C# 扩展类
C# 中提供一个非常实用的供能,扩展方法(Extension method) 扩展方法是通过额外的静态方法扩展现有的类型.通过扩展方法,可以对已有类型做自己想做的相关扩展.方法:定义静态类,扩展方法也 ...
- tp中调用PHP系统扩展类
例如使用Redis扩展类: use Reids; $redis = new Redis();
- Thinkphp编辑器扩展类kindeditor用法
一, 使用前的准备. 使用前请确认你已经建立好了一个Thinkphp站点项目. 1,Keditor.class.php和JSON.class.php 是编辑器扩展类文件,将他们拷贝到你的站点项目的Th ...
- 扩展javascript扩展(类,对象,原型)
扩展javascript扩展(类,对象,原型)
- 颜色扩展类--ColorExtensions
/// <summary> /// 颜色扩展类 /// </summary> public static class ColorExtensions { /// <sum ...
- PHP扩展类ZipArchive实现压缩解压Zip文件和文件打包下载
文章转载自:https://my.oschina.net/junn/blog/104464 PHP ZipArchive 是PHP自带的扩展类,可以轻松实现ZIP文件的压缩和解压,使用前首先要确保PH ...
- ASP.NET MVC4 HtmlHelper扩展类,实现分页功能 @Html.ShowPageNavigate
本文主要做了一个HtmHelper类的分页扩展函数,方便在视图中调用,有需要的朋友可以参考一下,希望对大家有所帮助. 1.扩展HtmlHelper类方法ShowPageNavigate output. ...
- C#操作Xml树的扩展类
本文提供一个操作Xml树的扩展类,与将xml字符串直接映射成实体对象的使用方法,供大家参考,学习. 下面附上源码 using System; using System.Collections.Gene ...
随机推荐
- 【Software Test】Introduction to Software Testing
Introduction to Software Testing 文章目录 Going to Learn --. Evolution of The Software Industry Errors, ...
- Springboot之文件监控
背景:在实际环境部署构成中,由于特殊网络环境因素,有很多服务器之间的网络都是单向的,不能互相访问的,只有通过特定技术手段做到文件的单项摆渡,这就需要在两台服务器上分别写序列化程序和反序列化程序,这里不 ...
- 全球城市ZoneId和UTC时间偏移量的最全对照表
前言 你好,我是A哥(YourBatman). 如你所知,现行的世界标准时间是UTC世界协调时,时区已不直接参与时间计算.但是呢,城市名称or时区是人们所能记忆和容易沟通的名词,因此我们迫切需要一个对 ...
- 1.5V升3V芯片和电路图,DC-DC升压IC
1.5V升3V的升压芯片,3V给LED供电,或者单片机模块供电等. PW5200A工作频率为1.4MHZ.轻载时自动PWM/PFM模式切换,提高效率. PW5200A能够提供2.5V和5V之间的可调输 ...
- numpy模块(详解)
重点 索引和切片 级联 聚合操作 统计操作 矩阵 什么是数据分析 是把隐藏在一些看似杂乱无章的数据背后的信息提炼出来,总结出所研究对象的内在规律 数据分析是用适当的方法对收集来的大量数据进行分析,帮助 ...
- pytest fixtures装饰器的使用
一.pytest中可以使用@pytest.fixture 装饰器来装饰一个方法,被装饰方法的方法名可以作为一个参数传入到测试方法中.可以使用这种方式来完成测试之前的初始化,也可以返回数据给测试函数. ...
- 转 2 jmeter常用功能介绍-测试计划、线程组
2 jmeter常用功能介绍-测试计划.线程组 1.测试计划测试用来描述一个性能测试,所有内容都是基于这个测试计划的. (1)User Defined Variables:设置用户全局变量.一般添 ...
- 自监督SOTA框架 | BYOL(优雅而简洁) | 2020
文章原创自微信公众号「机器学习炼丹术」 作者:炼丹兄 联系方式:微信cyx645016617 本篇文章主要讲解两个无监督2020年比较新比较火的论文: 论文名称:"Bootstrap You ...
- vim 行号的显示与隐藏
通常我们在使用vim编辑器的时候,需要显示和隐藏行号 隐藏行号: 1.首先我们vim 1.txt (进入我们编辑的文档),如下,此时是显示行号的 2.按一下esc键,并输入:(冒号),完成效果 ...
- 关于MongoDB的简单理解(三)--Spring Boot篇
一.前言 Spring Boot集成MongoDB非常简单,主要为加依赖,加配置,编码. 二.说明 环境说明: JDK版本为15(1.8+即可) Spring Boot 2.4.1 三.集成步骤 3. ...