如何解决字符串中可空Enum的扩展方法
我正在通过以下代码将一个类的Enum转换为另一类的Enum:
var someClassA.MyEnumA = (MyEnumA)Enum.Parse(typeof(MyEnumA),someClassB.MyEnumA.ToString());
我发现自己经常重复这段代码,所以我写了一个如下的辅助方法:
public static T EnumFromString<T>(string value)
{
return (T)Enum.Parse(typeof(T),value);
}
上面同一行中的用法是:
var someClassA.MyEnumA = EnumFromString<MyEnumA>(someClassB.MyEnumA.ToString());
这很好用。但是,现在我有了可以具有可空Enum的代码。所以我当前的代码是:
if (someClassB.MyEnumX.HasValue)
{
someClassA.MyEnumX = (MyEnumX)Enum.Parse(typeof(MyEnumX),someClassB.MyEnumX.ToString());
}
我不确定如何更新当前的辅助方法来处理这两种情况-还是只编写另一个名为NullableEnumFromString的辅助方法会更简单-我不确定泛型如何工作或什至可行?
解决方法
在我看来,这里的主要问题是,当您调用转换方法时,您已经将枚举值转换为string
,因此您无法知道原始值。类型是,没关系处理可为空的枚举类型。
从让所有呼叫者都必须自己呼叫ToString()
的角度来看,这对我来说似乎也不方便。
您可以通过编写两种不同的扩展方法来在这两个方面进行改进,一种用于常规枚举类型,另一种用于可为空的版本:
public static TResult Convert<T,TResult>(this T value)
where T : struct,System.Enum
where TResult : struct,System.Enum
{
return (TResult)Enum.Parse(typeof(TResult),value.ToString());
}
public static TResult? Convert<T,TResult>(this T? value)
where T : struct,System.Enum
where TResult : struct,System.Enum
{
return value != null ?
(TResult?)Enum.Parse(typeof(TResult),value.ToString()) : null;
}
注意:
- 上面使用了C#7.3功能,该功能允许约束
System.Enum
。如果使用的是C#的早期版本,则忽略它。它仍然可以工作,但是根本不会具有相同程度的编译时类型安全性。 - 尽管所有四个类型参数约束都指定了
struct
,但严格来说,这仅是第二个可空枚举版本所必需的。在第一个版本中它没有任何伤害。我只是为了保持一致性而已。 - 如果输入值为
null
,则此nullable-enum扩展方法将返回null
。您的问题并没有说明在这种情况下将使用什么值。如果您不打算这样做,则可以使用任何您喜欢的后备方式。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。