我正在编写一个确定.NET枚举中最高值的方法,因此我可以为每个枚举值创建一个BitArray:
- pressedKeys = new BitArray(highestValueInEnum<Keys>());
我需要两个不同的枚举,所以我把它变成了一个通用的方法:
- /// <summary>Returns the highest value encountered in an enumeration</summary>
- /// <typeparam name="EnumType">
- /// Enumeration of which the highest value will be returned
- /// </typeparam>
- /// <returns>The highest value in the enumeration</returns>
- private static int highestValueInEnum<EnumType>() {
- int[] values = (int[])Enum.GetValues(typeof(EnumType));
- int highestValue = values[0];
- for(int index = 0; index < values.Length; ++index) {
- if(values[index] > highestValue) {
- highestValue = values[index];
- }
- }
- return highestValue;
- }
如您所见,我将Enum.GetValues()的返回值转换为int [],而不是EnumType [].这是因为我以后不能将EnumType(这是一个泛型类型参数)转换为int.
代码有效.但它有效吗?
我是否可以始终将Enum.GetValues()的返回值转换为int []?
解决方法
不,你不能安全地转换为int [].枚举类型并不总是使用int作为基础值.如果你将自己局限于具有基础类型int的枚举类型,那么它应该没问题.
这就像你(或我)可以扩展Unconstrained Melody来支持你想要的东西 – 在编译时真正地将类型限制为枚举类型,并且适用于任何枚举类型,甚至是那些具有底层基础的类型,例如long和ulong.
如果没有Unconstrained Melody,您仍然可以使用所有枚举类型有效地实现IComparable的事实以一般方式执行此操作.如果您使用的是.NET 3.5,它就是一个单行程序:
- private static TEnum GetHighestValue<TEnum>() {
- return Enum.GetValues(typeof(TEnum)).Cast<TEnum>().Max();
- }