C#中Hashtable和Dictionary的區別與用法示例
前言
在.NET Framework中,Hashtable是System.Collections命名空間提供的一個容器,用於處理和表現類似keyvalue的鍵值對,其中key通常可用來快速查找,同時key是區分大小寫;value用於存儲對應於key的值。Hashtable中keyvalue鍵值對均為object類型,所以Hashtable可以支持任何類型的keyvalue鍵值對.
Hashtable與Dictionary,都是key/value鍵值對的形式,區別在於Hashtable的鍵值是object(DictionaryEntry),值類型,數據排列是亂序的;而Dictionary是泛型(KeyValuePair<T, T>),引用類型,按插入順序排列數據
Hashtable和Dictionary都是.Net下的表示鍵值對的集合,那麼我們在使用中該選擇Hashtable還是Dictionary?
下邊我們看看他們之間的區別:
1、Dictionary<K,V>在使用中是順序存儲的,而Hashtable由於使用的是哈希算法進行數據存儲,是無序的。
2、Dictionary的key和value是泛型存儲,Hashtable的key和value都是object
3、Dictionary是泛型存儲,不需要進行類型轉換,Hashtable由於使用object,在存儲或者讀取值時都需要進行類型轉換,所以比較耗時
4、單線程程序中推薦使用 Dictionary, 有泛型優勢, 且讀取速度較快, 容量利用更充分。多線程程序中推薦使用 Hashtable, 默認的 Hashtable 允許單線程寫入, 多線程讀取, 對 Hashtable 進一步調用 Synchronized() 方法可以獲得完全線程安全的類型. 而 Dictionary 非線程安全, 必須人為使用 lock 語句進行保護, 效率大減。
5、在通過代碼測試的時候發現key是整數型Dictionary的效率比Hashtable快,如果key是字符串型,Dictionary的效率沒有Hashtable快。
對於如何進行選擇,個人傾向於使用Dictionary,原因是:
1、Dictionary是可排序的,Hashtable如果想排序還需要采用別的方式進行
2、Dictionary有泛型優勢,效率要高
Hashtable用法舉例:
Hashtable hashtable = new Hashtable(); hashtable.Add("id", "BH0001"); hashtable.Add("name", "TM"); hashtable.Add("sex", "男"); Console.WriteLine("\t 鍵\t 值"); foreach (DictionaryEntry dicEntry in hashtable) Console.WriteLine("\t " + dicEntry.Key + "\t " + dicEntry.Value);
運行結果:
Dictionary用法舉例:
Dictionary<string,string> dictionary = new Dictionary<string, string>(); dictionary.Add("id", "BH0001"); dictionary.Add("name", "TM"); dictionary.Add("sex", "男"); Console.WriteLine("\t 鍵\t 值"); foreach (var dic in dictionary) Console.WriteLine("\t " + dic.Key + "\t " + dic.Value);
運行結果:
C# .net 3.5 以上的版本引入 Linq 後,字典Dictionary排序變得十分簡單,用一句類似 sql 數據庫查詢語句即可搞定;不過,.net 2.0 排序要稍微麻煩一點。下面舉例說明dictionary的排序方法:
dictionary按值value排序
Dictionary<string, int> dic = new Dictionary<string, int>(); dic.Add("index.html", 50); dic.Add("product.html", 13); dic.Add("aboutus.html", 4); dic.Add("online.aspx", 22); dic.Add("news.aspx", 18); private static void DictonarySort(Dictionary<string, int> dic) { var dicSort = from objDic in dic orderby objDic.Value descending select objDic; foreach (KeyValuePair<string, int> kvp in dicSort) Console.WriteLine(kvp.Key + ":" + kvp.Value ); }
排序結果:
index.html:50
online.aspx:22
news.aspx:18
product.html:13
aboutus.html:4
上述代碼是按降序(倒序)排列,如果想按升序(順序)排列,隻需要把變量 dicSort 右邊的 descending 去掉即可。
C# dictionary key 排序
如果要按 Key 排序,隻需要把變量 dicSort 右邊的 objDic.Value 改為 objDic.Key 即可。
總結
到此這篇關於C#中Hashtable和Dictionary的區別與用法的文章就介紹到這瞭,更多相關C# Hashtable和Dictionary區別內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- 聊聊C# 中HashTable與Dictionary的區別說明
- C#實現Dictionary字典賦值的方法
- .NET Core使用CZGL.SystemInfo庫獲取主機運行資源
- .Net中的弱引用字典WeakDictionary和ConditionalWeakTable介紹
- C#算法之羅馬數字轉整數