I am trying to obscure the index positions on an edi file... I had a situation where 2 or 3 things could be at an index based on the situation. It'd be cool to use an enum to hide the "magic numbers" and was suprised to see that you could assign multiple enums to the same value like this:
public enum Color
{
Red = 1,
Blue = 1,
Green = 1
}
and the compiler is happy with this. I didn't expect this to work. I don't need to cast back to the enum so I'm not worried about trying to go back, but this smells funky. Why does the CLR allow multiple values for enums and should I use a struct for this? (A struct seemed heavier duty than an enum and this seems to work)
If you think of each enum value as a constant, it makes sense. There's no reason why you shouldn't be able to have two constants with the same value:
Is the same as:
Essentially you just have the same constant with two different names.
BlueAndYellow
is an alias forGreen
.Actually your'e 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:
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.
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...
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
One thing to note here, is that non unique values result in missing and duplicated values in Visual Studio designer.
if you use this enum in a browable property you will see Green,Green,Blue in designer rather than Red, Green, Blue.
This would be a perfectly acceptable definition:
That's perfectly legal C#. From the C# Language specification version 4.0, section 14.3:
The same numeric value but different name is nothing else as an alias. It could be e.g.
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.