通过反射设置枚举值时,我刚刚遇到了一些奇怪的行为。看来我可以为枚举设置无效的值:
class EnumReflector
{
public enum MyEnum
{
Option1 = 0,
Option2,
Option3
}
public MyEnum TheEnum { get; set; }
public void Test()
{
PropertyInfo pi = this.GetType().GetProperty("TheEnum");
string badValue = "1234";
object propertyValue = Enum.Parse(pi.PropertyType, badValue, true);
pi.SetValue(this, propertyValue, null);
}
}
现在,如果我这样称呼:
EnumReflector e = new EnumReflector();
e.Test();
if (e.TheEnum == EnumReflector.MyEnum.Option1 ||
e.TheEnum == EnumReflector.MyEnum.Option2 ||
e.TheEnum == EnumReflector.MyEnum.Option3)
{
Console.WriteLine("Value is valid");
}
else
{
Console.WriteLine("Value is invalid: {0} ({1})", e.TheEnum.ToString(), (int)e.TheEnum);
}
输出为:
值无效:1234(1234)
怎么会这样?尽管枚举的本质之一是它们的限定值设置!
最佳答案
枚举只是具有定义的命名常量的整数(可以指定任何整数原始类型)。无需反射即可分配没有命名常量的值:
enum MyEnum {
None, One, Two
}
MyEnum e = (MyEnum)100;
编译并正常工作。请注意,这也是
Enum.IsDefined()
静态方法的原因,该方法检查枚举值是否为已定义的值。关于c# - 能够通过反射分配无效的Enum值,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/4276575/