古詩詞大全網 - 成語經典 - hashmap和hashtable的不同

hashmap和hashtable的不同

1 HashMap不是線程安全的

hastmap是壹個接口 是map接口的子接口,是將鍵映射到值的對象,其中鍵和值都是對象,並且不能包含重復鍵,但可以包含重復值。HashMap允許null key和null value,而hashtable不允許。

2 HashTable是線程安全的壹個Collection。

HashMap是Hashtable的輕量級實現(非線程安全的實現),他們都完成了Map接口,主要區別在於HashMap允許空(null)鍵值(key),由於非線程安全,效率上可能高於Hashtable。

HashMap允許將null作為壹個entry的key或者value,而Hashtable不允許。

HashMap把Hashtable的contains方法去掉了,改成containsvalue和containsKey。因為contains方法容易讓人引起誤解。

Hashtable繼承自Dictionary類,而HashMap是Java1.2引進的Map interface的壹個實現。

最大的不同是,Hashtable的方法是Synchronize的,而HashMap不是,在多個線程訪問Hashtable時,不需要自己為它的方法實現同步,而HashMap 就必須為之提供外同步。

Hashtable和HashMap采用的hash/rehash算法都大概壹樣,所以性能不會有很大的差異。

public static void main(String args[])

{

HashTable h=new HashTable();

h.put("用戶1",new Integer(90));

h.put("用戶2",new Integer(50));

h.put("用戶3",new Integer(60));

h.put("用戶4",new Integer(70));

h.put("用戶5",new Integer(80));

Enumeration e=h.elements();

while(e.hasMoreElements()){

System.out.println(e.nextElement());

}

map 的方法:

clear()從 Map 中刪除所有映射

remove(Object key)從 Map 中刪除鍵和關聯的值

put(Object key, Object value)將指定值與指定鍵相關聯

get(Object key)返回與指定鍵關聯的值

containsKey(Object key)如果 Map 包含指定鍵的映射,則返回 true

containsValue(Object value)如果此 Map 將壹個或多個鍵映射到指定值,則返回 true

isEmpty()如果 Map 不包含鍵-值映射,則返回 true size()返回 Map 中的鍵-值映射的數目

這些都代表了Java中的集合,這裏主要從其元素是否有序,是否可重復來進行區別記憶,以便恰當地使用,當然還存在同步方面的差異,見上壹篇相關文章。

有序否

允許元素重復否

Collection

List

Set

AbstractSet

HashSet

TreeSet

是(用二叉樹排序)

Map

AbstractMap

使用key-value來映射和存儲數據,Key必須惟壹,value可以重復

HashMap

TreeMap

是(用二叉樹排序)

List 接口對Collection進行了簡單的擴充,它的具體實現類常用的有ArrayList和LinkedList。妳可以將任何東西放到壹個List容器中,並在需要時從中取出。ArrayList從其命名中可以看出它是壹種類似數組的形式進行存儲,因此它的隨機訪問速度極快,而LinkedList的內部實現是鏈表,它適合於在鏈表中間需要頻繁進行插入和刪除操作。在具體應用時可以根據需要自由選擇。前面說的Iterator只能對容器進行向前遍歷,而 ListIterator則繼承了Iterator的思想,並提供了對List進行雙向遍歷的方法。

Set接口也是 Collection的壹種擴展,而與List不同的時,在Set中的對象元素不能重復,也就是說妳不能把同樣的東西兩次放入同壹個Set容器中。它的常用具體實現有HashSet和TreeSet類。HashSet能快速定位壹個元素,但是妳放到HashSet中的對象需要實現hashCode()方法,它使用了前面說過的哈希碼的算法。而TreeSet則將放入其中的元素按序存放,這就要求妳放入其中的對象是可排序的,這就用到了集合框架提供的另外兩個實用類Comparable和Comparator。壹個類是可排序的,它就應該實現Comparable接口。有時多個類具有相同的排序算法,那就不需要在每分別重復定義相同的排序算法,只要實現Comparator接口即可。集合框架中還有兩個很實用的公用類:Collections和 Arrays。Collections提供了對壹個Collection容器進行諸如排序、復制、查找和填充等壹些非常有用的方法,Arrays則是對壹個數組進行類似的操作。

Map是壹種把鍵對象和值對象進行關聯的容器,而壹個值對象又可以是壹個Map,依次類推,這樣就可形成壹個多級映射。對於鍵對象來說,像Set壹樣,壹個Map容器中的鍵對象不允許重復,這是為了保持查找結果的壹致性;如果有兩個鍵對象壹樣,那妳想得到那個鍵對象所對應的值對象時就有問題了,可能妳得到的並不是妳想的那個值對象,結果會造成混亂,所以鍵的唯壹性很重要,也是符合集合的性質的。當然在使用過程中,某個鍵所對應的值對象可能會發生變化,這時會按照最後壹次修改的值對象與鍵對應。對於值對象則沒有唯壹性的要求。妳可以將任意多個鍵都映射到壹個值對象上,這不會發生任何問題(不過對妳的使用卻可能會造成不便,妳不知道妳得到的到底是那壹個鍵所對應的值對象)。Map有兩種比較常用的實現: HashMap和TreeMap。HashMap也用到了哈希碼的算法,以便快速查找壹個鍵,TreeMap則是對鍵按序存放,因此它便有壹些擴展的方法,比如firstKey(),lastKey()等,妳還可以從TreeMap中指定壹個範圍以取得其子Map。鍵和值的關聯很簡單,用pub (Object key,Object value)方法即可將壹個鍵與壹個值對象相關聯。用get(Object key)可得到與此key對象所對應的值對象。