HashMap和Hashtable的比較是Java面試中的常見問題,用來考驗程式設計師是否能夠正確使用集合類別以及是否可以隨機應變使用多種思路解決問題。 HashMap的工作原理、ArrayList與Vector的比較以及這個問題是有關Java 集合框架的最經典的問題。 Hashtable是個過時的集合類,存在於Java API中很久了。在Java 4中被重寫了,實作了Map接口,所以自此以後也成了Java集合框架中的一部分。 Hashtable和HashMap在Java面試中相當容易被問到,甚至成為了集合框架面試題中最常被考試的問題,所以在參加任何Java面試之前,都不要忘了準備這一題。
這篇文章中,我們不僅將會看到HashMap和Hashtable的區別,還會看到它們之間的相似之處。
HashMap和Hashtable的區別
HashMap和Hashtable都實現了Map接口,但決定在哪一個之前先弄清楚它們之間的分別。主要的差異有:線程安全性,同步(synchronization),以及速度。
一、HashMap幾乎可以等價於Hashtable,除了HashMap是非synchronized的。
二、HashMap可以接受為 null 的鍵值(key)和值(value),而Hashtable 則不行。
三、HashMap是非synchronized,而Hashtable是synchronized。
這表示Hashtable是線程安全的,多個線程可以共享一個Hashtable;
並且如果沒有正確的同步的話,多個線程是不能共享HashMap的。
Java 5提供了ConcurrentHashMap,它是HashTable的替代,比HashTable的擴充性更好。
四、HashMap的迭代器(Iterator)是fail-fast迭代器,而Hashtable的 enumerator迭代器不是fail-fast的。
所以當有其它執行緒改變了HashMap的結構(增加或移除元素),將會拋出ConcurrentModificationException,但迭代器本身的remove()方法移除元素則不會拋出ConcurrentModificationException異常。但這並不是一定發生的行為,要看JVM。這同樣也是Enumeration和Iterator的差別。
五、由於Hashtable是執行緒安全的也是synchronized,所以在單執行緒環境下它比HashMap慢。如果你不需要同步,只需要單一線程,那麼使用HashMap效能就好過Hashtable。
六、HashMap無法保證隨著時間的推移Map中的元素順序是不變的。
所以在迭代時,如果對HashMap進行修改,則拋出例外。因為有的元素可能不會被迭代到。
要注意的一些重要術語:
1) sychronized意味著在一次只有一個執行緒能夠更改Hashtable。是說任何執行緒要更新Hashtable時要先取得同步鎖,其它執行緒要等到同步鎖被釋放之後才能再次獲得同步鎖更新Hashtable。
2) Fail-safe和iterator迭代器相關。如果某個集合物件建立了Iterator或ListIterator,然後其它的執行緒試圖「結構上」更改集合對象,將會拋出ConcurrentModificationException異常。但其它線程可以透過set()方法更改集合物件是允許的,因為這並沒有從「結構上」更改集合。但是假如已經從結構上進行了更改,再調用set()方法,將會拋出IllegalArgumentException異常。
3) 結構上的更改指的是刪除或插入一個元素,這樣會影響到map的結構。
我們能否讓HashMap同步?
HashMap可以透過下面的語句進行同步:
Java程式碼
Map m = Collections.synchronizeMap(hashMap); m = Collections.synchronizeMap(hashMap); Map有幾個主要的不同:線程安全以及速度。僅在你需要完全的線程安全的時候使用Hashtable,而如果你使用Java 5或以上的話,請使用ConcurrentHashMap吧。

本文討論了使用Maven和Gradle進行Java項目管理,構建自動化和依賴性解決方案,以比較其方法和優化策略。

本文使用Maven和Gradle之類的工具討論了具有適當的版本控制和依賴關係管理的自定義Java庫(JAR文件)的創建和使用。

本文討論了使用咖啡因和Guava緩存在Java中實施多層緩存以提高應用程序性能。它涵蓋設置,集成和績效優勢,以及配置和驅逐政策管理最佳PRA

本文討論了使用JPA進行對象相關映射,並具有高級功能,例如緩存和懶惰加載。它涵蓋了設置,實體映射和優化性能的最佳實踐,同時突出潛在的陷阱。[159個字符]

Java的類上載涉及使用帶有引導,擴展程序和應用程序類負載器的分層系統加載,鏈接和初始化類。父代授權模型確保首先加載核心類別,從而影響自定義類LOA


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

SublimeText3 Linux新版
SublimeText3 Linux最新版

Dreamweaver Mac版
視覺化網頁開發工具