public enum MyEnum { MyEnum1 = 1, //0x1 MyEnum2 = 1 << 1, //0x2 MyEnum3 = 1 << 2, //0x4 MyEnum4 = 1 << 3, //0x8 MyEnum5 = 1 << 4, //0x10 MyEnum6 = 1 << 5, //0x20 MyEnum7 = 1 << 6 //0x40 }
用位移运算方便的获取多个枚举的组合变量:html
MyEnum myEnum = MyEnum.MyEnum1 | MyEnum.MyEnum2;
myEnum |= myEnum | MyEnum.MyEnum3;
或在组合中删除其中一项枚举:post
myEnum ^= MyEnum.MyEnum1;
myEnum &= ~MyEnum.MyEnum2;
须要判断是否包含某一枚举值时,能够使用如下方法判断:url
(curMyEnum & MyEnum.Enum1) > 0
若是须要将枚举类型的变量视为一组标志,须要在枚举定义前加上Flages特性:spa
[System.Flags]
public enum MyEnum { }
具备Flags特性的枚举组合在调用实例方法ToString()时,会获得对应的枚举值组合,而非对应的枚举数:code
//对于以上枚举,若是不带Flags特性 Console.WriteLine(MyEnum.MyEnum1 | MyEnum.MyEnum2); //3 //对于以上枚举,若是带上Flags特性 Console.WriteLine(MyEnum.MyEnum1 | MyEnum.MyEnum2); //MyEnum1, MyEnum2 ※特性Flags通常和枚举组合一块儿使用,便于查看枚举中的枚举值的组合;