1. 程式人生 > >C#下Hashtable和Dictionary之間的差別

C#下Hashtable和Dictionary之間的差別

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有泛型優勢,效率要高
---------------------
作者:凡夢_
來源:CSDN
原文:https://blog.csdn.net/mpegfour/article/details/78725768
版權宣告:本文為博主原創文章,轉載請附上博文連結!