Click here to Skip to main content
Click here to Skip to main content

The Enum Keyword and Its Functional Usage

By , 16 May 2008
 

Introduction

The 'enum' Keyword is of Value Type. It is used to define integral constant and literals. It is inherited from the base class library(BCL) - 'Enum' where Enum's static methods are used by enum type for parsing enum values. This article tries to cover some of the enum functionality through code demonstration. Below is the source code which highlights various enum methods that are useful during the development phase.

Source Code

using System;
using System.Collections.Generic;
using System.Text;

namespace EnumSample
{
    class Program
    {
        public class EnumExamples
        {
            //Enum can also be derived from datatype-
            //Type byte, sbyte, short, ushort, int, uint, long, or ulong 
            public enum Status : byte
            { 
                REPORTED,
                OPEN,
                VERIFIED,
                CLOSED,
                REOPEN                
            }

            //Enum having Character Literal values
            public enum Colour 
            {
                RED='R',
                YELLOW='Y'                
            }

            //Enum having Numeric values
            public enum NumberType
            {
                WHOLE=0,
                NATURAl=1,
                EVEN=2,
                ODD=3
            }

            //MSDN --Example
            //http://msdn.microsoft.com/en-us/library/sbbt4032(VS.80).aspx
            [Flags]
            public enum CarOptions
            {
                SunRoof = 0x01,
                Spoiler = 0x02,
                FogLights = 0x04,
                TintedWindows = 0x08,
            }
            //END--

        }
        static void Main(string[] args)
        {
            //************************ENUM VALUES*******************************
            Console.WriteLine
                ("Output Enum Byte Value  : {0}",(byte)EnumExamples.Status.REPORTED);
            //Output Enum Byte Value  : 0
            Console.WriteLine("Output Enum Character Literal Value : 
                        {0}", (char)EnumExamples.Colour.RED);
            //Output Enum Character Literal Value : R
            Console.WriteLine("Output Enum Integer Value : {0}", 
                        (int)EnumExamples.NumberType.NATURAl);
            //Output Enum Integer Value : 1


            //************************ENUM NAMES*********************************
            Console.WriteLine("Output Enum Name as String Datatype : {0}",
                               EnumExamples.Status.REPORTED.ToString());
            //Output Enum Name as String Datatype :REPORTED
            Console.WriteLine("Output Enum Name as String Datatype : {0}",
                               EnumExamples.Colour.RED.ToString());
            //Output Enum Name as String Datatype :RED
            Console.WriteLine("Output Enum Name as String Datatype : {0}",
                               EnumExamples.NumberType.NATURAl.ToString());
            //Output Enum Name as String Datatype :NATURAL

            //****Enum.Parse--Input Parameter (typeof(enum),string)******
            Console.WriteLine("Output Enum.Parse Return As Typeof(Enum)
                               With IgnoreCase=False: {0}",
                               (EnumExamples.Status)Enum.Parse(typeof
                               (EnumExamples.Status), "REPORTED"));
            //Output Enum.Parse Return As Typeof(Enum) With 
              IgnoreCase=False: REPORTED
            Console.WriteLine("Output Enum.Parse Return As Typeof(Enum) 
                               With IgnoreCase=True: {0}", 
                               (EnumExamples.Status)Enum.Parse(typeof
                               (EnumExamples.Status), "reported", true));
            //Output Enum.Parse Return As Typeof(Enum) With 
              IgnoreCase=True: REPORTED

            //*****Enum.GetName--Input Parameter (typeof(enum),integer)*****
            Console.WriteLine("Output Enum.Parse Return As Typeof(Enum) :
                     {0}", Enum.GetName(typeof(EnumExamples.Status), 2));
            //Output Enum.Parse Return As Typeof(Enum) :VERIFIED
            
            
            //***Enum.ToObject --Input Parameter Can Be (Integer)|
              (Literal Constant)**
            Console.WriteLine("Output Enum.ToObject Return As Typeof(Enum) :
                     {0}", Enum.ToObject(typeof(EnumExamples.Colour), 'R'));
            //Output Enum.Parse Return As Typeof(Enum) :RED

            //******Enum.Format*********
            Console.WriteLine("Output Enum.Format Return As Typeof(Enum) :
                            {0}", Enum.Format(typeof(EnumExamples.Colour), 
                             EnumExamples.Colour.RED, "x"));
            //Output Enum.Format Return As Typeof(Enum) :00000052
            Console.WriteLine("Output Enum.Format Return As Typeof(Enum) : 
                              {0}", Enum.Format(typeof(EnumExamples.Colour),
                               EnumExamples.Colour.RED, "d"));
            //Output Enum.Format Return As Typeof(Enum) :82

            //****Enum.GetUnderlyingType *******
            Console.WriteLine("Output Enum.GetUnderlyingType Return Typeof
                               (Enum) : {0}", Enum.GetUnderlyingType(typeof
                               (EnumExamples.Colour)));
            //Output Enum.Format Return As Typeof(Enum) :System.Int32

            //****Enum.IsDefined-Input Parameter(Interger Only)for 'R'=82****
            Console.WriteLine("Output Enum.IsDefined Return as bool indicates
                    constant in the enum exist or not. : {0}", Enum.IsDefined
                   (typeof(EnumExamples.Colour), 82));
            //Output Enum.IsDefined Return as bool indicates constant in the
              enum exist or not.:82


            /*Enum.Names - To Load DropdownList--(TEXT)
             * Note that if one tries to load enum names into dropdownlist, one should
             * take note that enum only supports one word (no space).
            */
            int enumCounter = Enum.GetNames(typeof
             (EnumExamples.NumberType)).Length;                        
            foreach (string strName in Enum.GetNames(typeof
                   (EnumExamples.NumberType)))
            {
                Console.WriteLine("Enum for byte {0}: {1}", Enum.GetNames
          (typeof(EnumExamples.NumberType)).Length - enumCounter, strName);
                enumCounter--;
            }

            //Enum.Names - To Load DropdownList--(VALUE)
            int enumCounter1 = Enum.GetValues(typeof(EnumExamples.NumberType)).Length;
            foreach (int iValues in Enum.GetValues(typeof(EnumExamples.NumberType)))
            {
                Console.WriteLine("Enum for byte {0}: {1}", 
              Enum.GetValues
                  (typeof(EnumExamples.NumberType)).Length - enumCounter1, iValues);
                enumCounter1--;
            }
           
            //MSDN Example
            //http://msdn.microsoft.com/en-us/library/sbbt4032(VS.80).aspx
            EnumExamples.CarOptions options = EnumExamples.CarOptions.SunRoof
            | EnumExamples.CarOptions.FogLights;
            Console.WriteLine(options);
            Console.WriteLine((int)options);
            /* Output:
                SunRoof, FogLights
                5
            */
            /*
             * Notice that if you remove FlagsAttribute, 
             * the example will output the following:
             * 5
             * 5 
            */
            //END MSDN
            Console.Read();          
        }
    }
}

Feedback

I have tried to incorporate all the possible examples of enum which can be useful during development. Any suggestions or ideas about the functional usage of 'enum' will add more value to our learnings.

History

  • 16th May, 2008: Initial post

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)

About the Author

santosh poojari
Technical Lead
India India
Member
He is presently working as tech arch in one of the leading IT company.He has total 10 years of experience in C#.net. He is a B.E graduate in Computers from Bombay University.
 
Most of his experiences are in designing architect for end to end solutions. His interest areas are WCF,Spring.net,Architecture- Model View Presenter,UML,Webservice,Performance Engineering/tuning,Design patterns,Generics,Enterprise Library,Regular expressions,Silverlight and WWF.
www.santoshpoojari.blogspot.com

Sign Up to vote   Poor Excellent
Add a reason or comment to your vote: x
Votes of 3 or less require a comment

Comments and Discussions

 
Hint: For improved responsiveness ensure Javascript is enabled and choose 'Normal' from the Layout dropdown and hit 'Update'.
You must Sign In to use this message board.
Search this forum  
    Spacing  Noise  Layout  Per page   
GeneralEnum.IsDefined is slowmemberLehi16 Jul '09 - 22:20 
http://netinverse.com/devblogs/dotnet/avoid-enumisdefined/730/[^]
 
I am cool.

GeneralI love enumerationsmemberMember 150364516 May '08 - 3:32 
GeneralRe: I love enumerationsmemberPIEBALDconsult16 May '08 - 4:54 
GeneralRe: I love enumerationsmemberMember 150364516 May '08 - 5:39 
GeneralRe: I love enumerationsmemberPIEBALDconsult16 May '08 - 9:19 
GeneralRe: I love enumerationsmembersantosh poojari18 May '08 - 18:57 
GeneralNice one for the beginners!memberjohannesnestler16 May '08 - 2:01 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Permalink | Advertise | Privacy | Mobile
Web01 | 2.6.130516.1 | Last Updated 16 May 2008
Article Copyright 2008 by santosh poojari
Everything else Copyright © CodeProject, 1999-2013
Terms of Use
Layout: fixed | fluid