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有泛型優勢,效率要高

原文鏈接:https://blog.csdn.net/zhuhaiuser/article/details/127843371

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章