本文主要是我在實際項目中對C#枚舉的應用總結,如果存在不足的地方歡迎您指出。
一、枚舉基本運用
1、枚舉其實可以理解為一個恆量的結合,又或者可以認為它是一種類型。比如以下枚舉定義:
此枚舉默認值為int型,當然我們可以根據需要指定枚舉的數據類型。比如 public enum MicrosoftTechnology: long{....} 等。MicrosoftTechnology枚舉int值分別為
- public enum MicrosoftTechnology
- {
- CSharp,
- ASPNETMVC,
- SQLServer,
- WCF,
- SilverLight,
- }
Csharp:0;ASPNETMVC:1;SQLServer:2;WCF:3;SilverLight:4, 以自增1的形式自動賦值。當然也可以指定每個枚舉項的值。
2、枚舉的位運算:
Flag特性表示枚舉支持位運算。一般情況下我們用到的位運算符有:&(與)、|(或)、~(非)。
首先我們為枚舉加上[Flags]特性後再指定枚舉值。
將1、中的代碼修改如下:
- [Flags] public enum MicrosoftTechnology
- {
- CSharp = 1,
- ASPNETMVC = 2,
- SQLServer = 4,
- WCF = 8,
- SilverLight = 16,
- }
這裡指定枚舉值主要是為了使用與、或、非這三個位運算符。將枚舉值轉化成二進制值:
CSharp: 1 = 0001
ASPNETMVC: 2 = 0010
SQLServer: 4 = 0100
WCF: 8 = 1000
SilverLight: 16 = 10000
舉例說明:如果某位開發者選擇兩項微軟技術分別為CSharp和ASPNETMVC 用位運算表達為 0001 | 0010 = 0011。經過不懈的努力這位開發者掌握了以上兩項技術“0011”。現在我們想通過位運算檢測出這位開發者是否精通CSharp:代碼為:
(MicrosoftTechnology.CSharp|MicrosoftTechnology.ASPNETMVC) & MicrosoftTechnology.CSharp 等同 (0001 | 0010 = 0011)& 0001 等於 0001(CSharp :1)
講到這裡我想您應該不難理解:為了對枚舉運用位操作時指定枚舉值的緣故了。非(~)操作符這裡就留給讀者自己實踐了。
二、為枚舉進行本地化
通過.Net泛型機制編寫枚舉本地化通用方法,代碼如下:
- /// <summary>
- /// 本地化枚舉通用方法
- /// </summary>
- /// <returns></returns>
- /// <author>Ryanding</author>
- private static string LocalizeEnumeration(object enumerator)
- {
- ResourceManager resources = new ResourceManager("resx文件名",
- System.Reflection.Assembly.GetExecutingAssembly());
- string name = String.Format("{0}.{1}.Text", enumerator.GetType().Name, enumerator);
- string localizedDescription = resources.GetString(name);
- if (localizedDescription == null)
- return enumerator.ToString();
- else18 return localizedDescription;
- }
- /// <summary>
- /// 翻譯枚舉成中文
- /// </summary>
- public static List<KeyValuePair> GetEnumStringList<T>()
- {
- string[] resultPrepare = Enum.GetNames(typeof(T));
- List<KeyValuePair> result = new List<KeyValuePair>();
- Array.ForEach(resultPrepare, f => result.Add(new KeyValuePair
- {
- Key = (int)(Enum.Parse(typeof(T), f)),
- Value = LocalizeEnumeration(Enum.Parse(typeof(T), f))
- }
- ));
- return result;
- }
通過以上代碼,可以認為枚舉也是一種類型。這裡通過泛型機制將枚舉本地化統一處理。
三、枚舉在ORM中提高程序可讀性
以LinqToSQL來列舉枚舉在ORM中的作用:
在大中型系統中設計數據庫表時,比如有一張Customer表,存在一字段CustomerType(int 型) 。
CustomerType 枚舉定義如下:
- public enum CustomerType
- {
- Trader = 0,
- SupplIEr = 1,
- Logistics = 2,
- }
Customer表結構如下:
LinqTosql debug如下:
可以看出LinqTosql 已經很“完美”的將LINQ語句解析成SQL語句。這樣當我們的業務變得相對復雜,枚舉狀態數量也逐漸增加時,開發者無需硬記0,1,2,3這些到底代表數據的何種業務狀態。通過枚舉映射到ORM,我們的代碼可讀性進一步加強。當然更便於維護了!
最後希望本篇文章可以給您帶來幫助,如有不足之處歡迎指出,謝謝!
原文鏈接:http://www.cnblogs.com/ryanding/archive/2010/12/08/1898794.Html
【編輯推薦】