我写了以下代码进行一些测试,输出不符合我的期望.
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字节以允许最大可能的枚举类型?价值型继承基本上导致了期望的问题,这就是为什么它被禁止(我相信).这些原因与枚举一样适用于其他类型.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。