Hashtable和HashMap
Hashtable和HashMap類(lèi)有三個(gè)重要的不同之處。第一個(gè)不同主要是歷史原因。Hashtable是基于陳舊的Dictionary類(lèi)的,HashMap是Java 1.2引進(jìn)的Map接口的一個(gè)實(shí)現。
也許最重要的不同是Hashtable的方法是同步的,而HashMap的方法不是。這就意味著(zhù),雖然你可以不用采取任何特殊的行為就可以在一個(gè)多線(xiàn)程的應用程序中用一個(gè)Hashtable,但你必須同樣地為一個(gè)HashMap提供外同步。一個(gè)方便的方法就是利用Collections類(lèi)的靜態(tài)的synchronizedMap()方法,它創(chuàng )建一個(gè)線(xiàn)程安全的Map對象,并把它作為一個(gè)封裝的對象來(lái)返回。這個(gè)對象的方法可以讓你同步訪(fǎng)問(wèn)潛在的HashMap。這么做的結果就是當你不需要同步時(shí),你不能切斷Hashtable中的同步(比如在一個(gè)單線(xiàn)程的應用程序中),而且同步增加了很多處理費用。
第三點(diǎn)不同是,只有HashMap可以讓你將空值作為一個(gè)表的條目的key或value。HashMap中只有一條記錄可以是一個(gè)空的key,但任意數量的條目可以是空的value。這就是說(shuō),如果在表中沒(méi)有發(fā)現搜索鍵,或者如果發(fā)現了搜索鍵,但它是一個(gè)空的值,那么get()將返回null。如果有必要,用containKey()方法來(lái)區別這兩種情況。
一些資料建議,當需要同步時(shí),用Hashtable,反之用HashMap。但是,因為在需要時(shí),HashMap可以被同步,HashMap的功能比Hashtable的功能更多,而且它不是基于一個(gè)陳舊的類(lèi)的,所以有人認為,在各種情況下,HashMap都優(yōu)先于Hashtable。
聯(lián)系客服