给定一个对象,这是一个枚举值数组,如何在不知道枚举类型的情况下获取Enum []

Mic*_*eyn 4 .net c#

如何将包含某个枚举类型数组的对象类型变量转换为Enum []?换一种说法:

// Somewhere in the code we have: public enum MyEnum {This,That};
// Somewhere else in the code we have: public enum TheirEnum {What,Ever};
// In other parts of the code we have additional enum types

// Now, given:
object enumArrayOfSomeType=...; // Maybe it's of type MyEnum[] or TheirEnum[] or 
                                // SomeOtherEnum[]

// I want to say
Enum[] someEnumArray=enumArrayOfSomeType as Enum[];
Run Code Online (Sandbox Code Playgroud)

不幸的是,所呈现的代码总是在someEnumArray中产生空值.

有没有办法做到这一点?

更新:

我想我期待阵列协方差开始,但也许我期待太多(即阵列协方差变得疯狂).

此外,由于克里斯·辛克莱在评论接受的答案指出阵列的协方差适用于参考类型的枚举肯定不是.(请参阅:MSDN中的.NET数组协方差规则.)

Chr*_*air 6

我怀疑你必须创建一个新数组并转换每个元素,因为a MyEnum[]不是Enum[].一个简单的LINQ查询可以做到这一点:

Enum[] someEnumArray = ((IEnumerable)enumArrayOfSomeType).Cast<Enum>().ToArray();
Run Code Online (Sandbox Code Playgroud)

编辑:根据您的意见,如果您只想迭代一次并避免创建数组,您可以放弃ToArray()调用并将其视为延迟IEnumerable<Enum>:

IEnumerable<Enum> someEnumArray = ((IEnumerable)enumArrayOfSomeType).Cast<Enum>();
Run Code Online (Sandbox Code Playgroud)

所以它本质上只是迭代元素并一次抛出一个元素.

EDITx2:从编辑过的问题到为什么数组协方差没有起作用,这是因为它仅适用于枚举不是的引用类型.从MSDN 12.5阵列协方差:

对于任何两个引用类型 A和B,如果从A到B存在隐式引用转换(第6.1.4节)或显式引用转换(第6.2.3节),则数组类型A中也存在相同的引用转换[ R]到阵列类型B [R]