Non-unique enum values
Actually you're already defining a struct... Behind the scenes an enum is just a struct (but which derives from System.Enum) and the values of the enum are defined as constants (you can verify this with ILDASM).
Your enum definition translates into the following pseudo C# code:
public struct Color : System.Enum
{
public const int Red = 1;
public const int Blue = 1;
public const int Green = 1;
}
The above code won't compile in C# because the compiler doesn't allow defining a struct with an explicit base class, but that's what it emits for an enum definition.
Since there is no problem with a type that contains an multiple constants that have the same value, there is no problem with the enum definition.
But since the enum does not have unique values you might have an issue when converting into this enum. For example the following two line of codes will return the enum value Red, because the first value is arbitrarily selected.
Color color1 = (Color)1;
Color color2 = (Color)Enum.Parse(typeof(Color), "1");
Strictly speaking the enum value is not Red, it is 1, but when you print out the value you'll see Red.
Also, the following boolean is true which looks a bit weird...
// true (Red is Green??)
bool b = Color.Red == Color.Green;
At the bottom line this is perfectly legal, but it's up to you to use it when it makes sense...
Here is a direct link to the section of my .NET tutorial that discusses enumerations under the hood: http://motti.me/c1E
That's perfectly legal C#. From the C# Language specification version 4.0, section 14.3:
Multiple enum members may share the same associated value. The example
enum Color { Red, Green, Blue, Max = Blue }
shows an enum in which two enum members—Blue and Max—have the same associated value.
The same numeric value but different name is nothing else as an alias. It could be e.g.
public enum Color
{
DefaultColor = 1,
Red = 1,
Blue = 2
}
It can make sense in some cases but not many. When you parse the values back and call colorValue.ToString() you will get the last value as stringified value back (Red in this case) but you will loose the conept of default colors since it is the same thing. At least in the way you did model your data. If you want to keep it separate use different values for different things.
This would be a perfectly acceptable definition:
public enum AllTheThings
{
TheMoney = 1,
TheFreeRides = 1,
TheLieThatYouDenied = 2,
TheCallsYouveBeenMaking = 3,
TheTimesYouveBeenFaking = 4
}