Flags Enum Attribute
- Use the [Flags] attribute to represent the enum as a bit field.
- The [Flags] attribute should be used whenever the enumerable represents a collection of possible values, rather than a single value. Such collections are often used with bitwise operators.
[Flags]
public enum SignalColor
{
None = 0,//0000
Red = 1,//0001
Green = 2,//0010
Yellow = 4,//0100
Stop = Red | Yellow//0101
}
public class FlagsEnum
{
public static void Test()
{
//SignalColor.Stop & SignalColor.Red == SignalColor.Red
if (SignalColor.Stop.HasFlag(SignalColor.Red))
{
Console.WriteLine("Red is to stop");
}
}
}
Explanation of the above code
- The value of SignalColor.Stop is 0101 in binary (which is 5 in decimal).
- The value of SignalColor.Red is 0001 in binary (which is 1 in decimal).
When you perform a bitwise AND operation between SignalColor.Stop (0101) and SignalColor.Red (0001), the result is.
- 0101 (Stop)
- 0001 (Red)
Result
0001 (which equals SignalColor.Red)
Summary
The SignalColor enum uses the [Flags] attribute to represent a combination of signal colors using bitwise operations.