HashMap&Hashtable區(qū)別

轉(zhuǎn)

一.關(guān)鍵術(shù)語(yǔ):

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

  2. Fail-safe和iterator迭代器相關(guān)颠通。如果某個(gè)集合對(duì)象創(chuàng)建了Iterator或者ListIterator娇跟,然后其它的線程試圖“結(jié)構(gòu)上”更改集合對(duì)象僻爽,將會(huì)拋出ConcurrentModificationException異常。但其它線程可以通過(guò)set()方法更改集合對(duì)象是允許的呛哟,因?yàn)檫@并沒(méi)有從“結(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)鳖孤。

  4. fail-fast 和 fail-safe的區(qū)別:

  • fail-fast:
    fail-fast機(jī)制在遍歷一個(gè)集合時(shí)者娱,當(dāng)集合結(jié)構(gòu)被修改,會(huì)拋出Concurrent Modification Exception苏揣。
    fail-fast會(huì)在以下兩種情況下拋出ConcurrentModificationException
    (1)單線程環(huán)境
    集合被創(chuàng)建后黄鳍,在遍歷它的過(guò)程中修改了結(jié)構(gòu)。
    注意 remove()方法會(huì)讓expectModcount和modcount 相等平匈,所以是不會(huì)拋出這個(gè)異常框沟。
    (2)多線程環(huán)境
    當(dāng)一個(gè)線程在遍歷這個(gè)集合,而另一個(gè)線程對(duì)這個(gè)集合的結(jié)構(gòu)進(jìn)行了修改增炭。

  • fail-safe:
    fail-safe任何對(duì)集合結(jié)構(gòu)的修改都會(huì)在一個(gè)復(fù)制的集合上進(jìn)行修改忍燥,因此不會(huì)拋出ConcurrentModificationException
    fail-safe機(jī)制有兩個(gè)問(wèn)題
    (1)需要復(fù)制集合,產(chǎn)生大量的無(wú)效對(duì)象隙姿,開(kāi)銷大
    (2)無(wú)法保證讀取的數(shù)據(jù)是目前原始數(shù)據(jù)結(jié)構(gòu)中的數(shù)據(jù)梅垄。

詳解:http://blog.csdn.net/ch717828/article/details/46892051

二.區(qū)別:

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

  1. HashMap幾乎可以等價(jià)于Hashtable炭玫,除了HashMap是非synchronized的,并可以接受null(HashMap可以接受為null的鍵值(key)和值(value)貌虾,而Hashtable則不行)吞加。
  2. HashMap是非synchronized,而Hashtable是synchronized,這意味著Hashtable是線程安全的衔憨,多個(gè)線程可以共享一個(gè)Hashtable叶圃;而如果沒(méi)有正確的同步的話,多個(gè)線程是不能共享HashMap的践图。Java 5提供了ConcurrentHashMap掺冠,它是HashTable的替代,比HashTable的擴(kuò)展性更好码党。
  3. 另一個(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ū)別。
區(qū)別:
Enumeration速度是Iterator的2倍箕慧,同時(shí)占用更少的內(nèi)存服球。
但是,Iterator遠(yuǎn)遠(yuǎn)比Enumeration安全销钝,因?yàn)槠渌€程不能夠修改正在被iterator遍歷的集合里面的對(duì)象有咨。
同時(shí),Iterator允許調(diào)用者刪除底層集合里面的元素蒸健,這對(duì)Enumeration來(lái)說(shuō)是不可能的座享。
  1. 由于Hashtable是線程安全的也是synchronized,所以在單線程環(huán)境下它比HashMap要慢似忧。如果你不需要同步渣叛,只需要單一線程,那么使用HashMap性能要好過(guò)Hashtable盯捌。

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

  3. HashMap可以通過(guò)下面的語(yǔ)句進(jìn)行同步:

Map m = Collections.synchronizeMap(hashMap);

三.結(jié)論:

Hashtable和HashMap有幾個(gè)主要的不同:線程安全以及速度。僅在你需要完全的線程安全的時(shí)候使用Hashtable饺著,而如果你使用Java 5或以上的話箫攀,請(qǐng)使用ConcurrentHashMap吧。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末幼衰,一起剝皮案震驚了整個(gè)濱河市靴跛,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌渡嚣,老刑警劉巖梢睛,帶你破解...
    沈念sama閱讀 211,817評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件肥印,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡绝葡,警方通過(guò)查閱死者的電腦和手機(jī)深碱,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,329評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)藏畅,“玉大人敷硅,你說(shuō)我怎么就攤上這事∧垢埃” “怎么了竞膳?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,354評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)诫硕。 經(jīng)常有香客問(wèn)我,道長(zhǎng)刊侯,這世上最難降的妖魔是什么章办? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,498評(píng)論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮滨彻,結(jié)果婚禮上藕届,老公的妹妹穿的比我還像新娘。我一直安慰自己亭饵,他們只是感情好休偶,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,600評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著辜羊,像睡著了一般踏兜。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上八秃,一...
    開(kāi)封第一講書(shū)人閱讀 49,829評(píng)論 1 290
  • 那天碱妆,我揣著相機(jī)與錄音,去河邊找鬼昔驱。 笑死疹尾,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的骤肛。 我是一名探鬼主播纳本,決...
    沈念sama閱讀 38,979評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼腋颠!你這毒婦竟也來(lái)了繁成?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,722評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤秕豫,失蹤者是張志新(化名)和其女友劉穎朴艰,沒(méi)想到半個(gè)月后观蓄,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,189評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡祠墅,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,519評(píng)論 2 327
  • 正文 我和宋清朗相戀三年侮穿,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片毁嗦。...
    茶點(diǎn)故事閱讀 38,654評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡亲茅,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出狗准,到底是詐尸還是另有隱情克锣,我是刑警寧澤,帶...
    沈念sama閱讀 34,329評(píng)論 4 330
  • 正文 年R本政府宣布腔长,位于F島的核電站袭祟,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏捞附。R本人自食惡果不足惜巾乳,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,940評(píng)論 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望鸟召。 院中可真熱鬧胆绊,春花似錦、人聲如沸欧募。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,762評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)跟继。三九已至种冬,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間还栓,已是汗流浹背碌廓。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,993評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留剩盒,地道東北人谷婆。 一個(gè)月前我還...
    沈念sama閱讀 46,382評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像辽聊,于是被迫代替她去往敵國(guó)和親纪挎。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,543評(píng)論 2 349

推薦閱讀更多精彩內(nèi)容