我写了以下代码进行一些测试,输出不符合我的期望.
public enum Days { Saturday,Sunday,Monday,Tuesday,Wednesday,Thursday,Friday }; Console.WriteLine(typeof(System.Enum).IsValueType.ToString()); // False Console.WriteLine(typeof(Days).IsValueType.ToString()); // True
所以我检查Reflector的Type.IsValueType属性的实现.哪个是:
public bool get_IsValueType() { return this.IsValueTypeImpl(); } protected virtual bool IsValueTypeImpl() { Type type = this; return (((type != valueType) && (type != enumType)) && this.IsSubclassOf(valueType)); }
在MSDN中,System.Enum定义为:
[SerializableAttribute] [ComVisibleAttribute(true)] public abstract class Enum : ValueType,IComparable,IFormattable,IConvertible
那么为什么IsValueType这个意思呢?为什么有enumType的检测?
解决方法
所有枚举都继承自System.Enum.您不能从值类型继承,因此System.Enum不能是值类型.
它就像System.ValueType不是一个值类型.这只是一个微乎其微的奇怪的事情.要给出一个更具体的问题示例,请参考以下代码:
enum Foo : int { X } enum Bar : long { Y } ... Enum x = Foo.X; x = Bar.Y;
x的堆栈应该保留多少空间?应该是0字节,因为System.Enum本身没有任何字段(因此截断分配上的数据)?应该是8字节以允许最大可能的枚举类型?价值型继承基本上导致了期望的问题,这就是为什么它被禁止(我相信).这些原因与枚举一样适用于其他类型.