最美情侣中文字幕电影,在线麻豆精品传媒,在线网站高清黄,久久黄色视频

歡迎光臨散文網(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)論 (共 條)

使用qq登录你需要登录后才可以评论。
武威市| 乡城县| 梁平县| 清河县| 平原县| 旺苍县| 宁南县| 娱乐| 伽师县| 安龙县| 莱州市| 平凉市| 珲春市| 珠海市| 吴旗县| 涿州市| 开鲁县| 金寨县| 分宜县| 日照市| 靖州| 无极县| 柯坪县| 泾阳县| 中宁县| 刚察县| 宜川县| 延庆县| 务川| 紫阳县| 宜城市| 舞钢市| 凤台县| 兖州市| 西城区| 濮阳市| 鄂伦春自治旗| 竹溪县| 桦川县| 泸溪县| 绥江县|