Java中HashMap,LinkedHashMap,TreeMap的區別

    Java數據結構中的映射定義了一個接口java.util.Map;它有四個實現類,分別是HashMap Hashtable LinkedHashMap 和TreeMap
    Map主要用於存儲健值對,根據鍵獲得值,所以不容許鍵重複(重複了覆蓋了),但容許值重複。
    Hashmap 是一個最經常使用的Map,它根據鍵的HashCode 值存儲數據,根據鍵能夠直接獲取它的值,具備很快的訪問速度,遍歷時,取得數據的順序是徹底隨機的。HashMap最多隻容許一條記錄的鍵爲Null;容許多條記錄的值爲 Null;HashMap不支持線程的同步,即任一時刻能夠有多個線程同時寫HashMap;可能會致使數據的不一致。若是須要同步,能夠用 Collections的synchronizedMap方法使HashMap具備同步的能力,或者使用ConcurrentHashMap。
    Hashtable與 HashMap相似,它繼承自Dictionary類,不一樣的是:它不容許記錄的鍵或者值爲空;它支持線程的同步,即任一時刻只有一個線程能寫Hashtable,所以也致使了 Hashtable在寫入時會比較慢。
    LinkedHashMap保存了記錄的插入順序,在用Iterator遍歷LinkedHashMap時,先獲得的記錄確定是先插入的.也能夠在構造時用帶參數,按照應用次數排序。在遍歷的時候會比HashMap慢,不過有種狀況例外,當HashMap容量很大,實際數據較少時,遍歷起來可能會比LinkedHashMap慢,由於LinkedHashMap的遍歷速度只和實際數據有關,和容量無關,而HashMap的遍歷速度和他的容量有關。
TreeMap實現SortMap接口,可以把它保存的記錄根據鍵排序,默認是按鍵值的升序排序,也能夠指定排序的比較器,當用Iterator 遍歷TreeMap時,獲得的記錄是排過序的。java

    通常狀況下,咱們用的最多的是HashMap,HashMap裏面存入的鍵值對在取出的時候是隨機的,它根據鍵的HashCode值存儲數據,根據鍵能夠直接獲取它的值,具備很快的訪問速度。在Map 中插入、刪除和定位元素,HashMap 是最好的選擇。
    TreeMap取出來的是排序後的鍵值對。但若是您要按天然順序或自定義順序遍歷鍵,那麼TreeMap會更好。
    LinkedHashMap 是HashMap的一個子類,若是須要輸出的順序和輸入的相同,那麼用LinkedHashMap能夠實現,它還能夠按讀取順序來排列,像鏈接池中能夠應用。數據結構

 

    如下代碼實例能夠看出HashMap,LinkedHashMap,TreeMap的區別:.net

import java.util.HashMap;  
import java.util.Iterator;  
import java.util.LinkedHashMap;  
import java.util.Map;  
import java.util.TreeMap;  
public class Ceshi{  
@SuppressWarnings("unchecked")  
public static void main(String[] args) {  
  
//HashMap  
System.out.println("------HashMap無序輸出------");  
HashMap hsMap=new HashMap();  
hsMap.put("3", "Value3");  
hsMap.put("1", "Value1");  
hsMap.put("2", "Value2");  
hsMap.put("b", "ValueB");  
hsMap.put("a", "ValueA");  
Iterator it = hsMap.entrySet().iterator();  
while (it.hasNext()) {  
Map.Entry e = (Map.Entry) it.next();  
System.out.println("Key: " + e.getKey() + "--Value: "  
+ e.getValue());  
}  
  
//TreeMap  
System.out.println("------TreeMap按Key排序輸出------");  
TreeMap teMap=new TreeMap();  
teMap.put("3", "Value3");  
teMap.put("1", "Value1");  
teMap.put("2", "Value2");  
teMap.put("b", "ValueB");  
teMap.put("a", "ValueA");  
Iterator tit = teMap.entrySet().iterator();  
while (tit.hasNext()) {  
Map.Entry e = (Map.Entry) tit.next();  
System.out.println("Key: " + e.getKey() + "--Value: "  
+ e.getValue());  
}  
  
//LinkedHashMap  
System.out.println("--LinkedHashMap根據輸入的順序輸出--");  
LinkedHashMap lhsMap=new LinkedHashMap();  
lhsMap.put("3", "Value3");  
lhsMap.put("1", "Value1");  
lhsMap.put("2", "Value2");  
lhsMap.put("b", "ValueB");  
lhsMap.put("a", "ValueA");  
Iterator lit = lhsMap.entrySet().iterator();  
while (lit.hasNext()) {  
Map.Entry e = (Map.Entry) lit.next();  
System.out.println("Key: " + e.getKey() + "--Value: "  
+ e.getValue());  
}  
}  
  
}

執行結果爲:線程


------HashMap無序輸出------
Key: 3--Value: Value3
Key: 2--Value: Value2
Key: 1--Value: Value1
Key: b--Value: ValueB
Key: a--Value: ValueAcode


------TreeMap按Key排序輸出------
Key: 1--Value: Value1
Key: 2--Value: Value2
Key: 3--Value: Value3
Key: a--Value: ValueA
Key: b--Value: ValueB排序


--LinkedHashMap根據輸入的順序輸出--
Key: 3--Value: Value3
Key: 1--Value: Value1
Key: 2--Value: Value2
Key: b--Value: ValueB
Key: a--Value: ValueA繼承

相關文章
相關標籤/搜索