国产精品天干天干,亚洲毛片在线,日韩gay小鲜肉啪啪18禁,女同Gay自慰喷水

歡迎光臨散文網(wǎng) 會(huì)員登陸 & 注冊(cè)

HashTable和HashMap的區(qū)別

2018-10-19 09:22 作者:動(dòng)力節(jié)點(diǎn)  | 我要投稿

  HashMap和Hashtable都實(shí)現(xiàn)了Map接口,但決定用哪一個(gè)之前先要弄清楚它們之間的分別。主要的區(qū)別有:線程安全性,同步(synchronization),以及速度。

  HashMap幾乎可以等價(jià)于Hashtable,除了HashMap是非synchronized的,并可以接受null(HashMapallowsonenullkeyandanynumberofnullvalues.,而Hashtable則不行)。這就是說,HashMap中如果在表中沒有發(fā)現(xiàn)搜索鍵,或者如果發(fā)現(xiàn)了搜索鍵,但它是一個(gè)空的值,那么get()將返回null。如果有必要,用containKey()方法來區(qū)別這兩種情況。


  HashMap是非synchronized,而Hashtable是synchronized,這意味著Hashtable是線程安全的,多個(gè)線程可以共享一個(gè)Hashtable;而如果沒有正確的同步的話,多個(gè)線程是不能共享HashMap的。即是說,在多線程應(yīng)用程序中,不用專門的操作就安全地可以使用Hashtable了;而對(duì)于HashMap,則需要額外的同步機(jī)制。但HashMap的同步問題可通過Collections的一個(gè)靜態(tài)方法得到解決:


  MapCollections.synchronizedMap(Mapm)


  這個(gè)方法返回一個(gè)同步的Map,這個(gè)Map封裝了底層的HashMap的所有方法,使得底層的HashMap即使是在多線程的環(huán)境中也是安全的。而且Java5提供了ConcurrentHashMap,它是HashTable的替代,比HashTable的擴(kuò)展性更好。


  另一個(gè)區(qū)別是HashMap的迭代器(Iterator)是fail-fast迭代器,而Hashtable的enumerator迭代器不是fail-fast的。所以當(dāng)有其它線程改變了HashMap的結(jié)構(gòu)(增加或者移除元素),將會(huì)拋出ConcurrentModificationException,但迭代器本身的remove()方法移除元素則不會(huì)拋出ConcurrentModificationException異常。但這并不是一個(gè)一定發(fā)生的行為,要看JVM。這條同樣也是Enumeration和Iterator的區(qū)別。


  由于Hashtable是線程安全的也是synchronized,所以在單線程環(huán)境下它比HashMap要慢。如果你不需要同步,只需要單一線程,那么使用HashMap性能要好過Hashtable。


  HashMap不能保證隨著時(shí)間的推移Map中的元素次序是不變的。


  哈希值的使用不同,HashTable直接使用對(duì)象的hashCode,代碼是這樣的:


  inthash=key.hashCode();


  intindex=(hash&0x7FFFFFFF)%tab.length;


  而HashMap重新計(jì)算hash值,而且用與代替求模:


  inthash=hash(k);


  inti=indexFor(hash,table.length);


  要注意的一些重要術(shù)語:


  1)sychronized意味著在一次僅有一個(gè)線程能夠更改Hashtable。就是說任何線程要更新Hashtable時(shí)要首先獲得同步鎖,其它線程要等到同步鎖被釋放之后才能再次獲得同步鎖更新Hashtable。


  2)Fail-safe和iterator迭代器相關(guān)。如果某個(gè)集合對(duì)象創(chuàng)建了Iterator或者ListIterator,然后其它的線程試圖“結(jié)構(gòu)上”更改集合對(duì)象,將會(huì)拋出ConcurrentModificationException異常。但其它線程可以通過set()方法更改集合對(duì)象是允許的,因?yàn)檫@并沒有從“結(jié)構(gòu)上”更改集合。但是假如已經(jīng)從結(jié)構(gòu)上進(jìn)行了更改,再調(diào)用set()方法,將會(huì)拋出IllegalArgumentException異常。


  3)結(jié)構(gòu)上的更改指的是刪除或者插入一個(gè)元素,這樣會(huì)影響到map的結(jié)構(gòu)。

HashTable和HashMap的區(qū)別的評(píng)論 (共 條)

分享到微博請(qǐng)遵守國家法律
普格县| 乌审旗| 青岛市| 苍梧县| 金堂县| 德化县| 阿合奇县| 荆州市| 根河市| 治县。| 天长市| 正镶白旗| 永德县| 获嘉县| 沁水县| 曲靖市| 祁门县| 浏阳市| 犍为县| 楚雄市| 鄂托克旗| 天台县| 贺州市| 田东县| 荆州市| 从化市| 昌江| 菏泽市| 临桂县| 开鲁县| 诏安县| 屯昌县| 裕民县| 平邑县| 洛川县| 旬阳县| 鹿泉市| 句容市| 民权县| 合山市| 如东县|