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有泛型優勢,效率要高
原文鏈接:https://blog.csdn.net/zhuhaiuser/article/details/127843371