HashMap和HashSet一網(wǎng)打盡

簡(jiǎn)介

HashMap和HashSet都是collection框架的一部分,它們讓我們能夠使用對(duì)象的集合。collection框架有自己的接口和實(shí)現(xiàn),主要分為Set接口,List接口和Queue接口。它們有各自的特點(diǎn),Set的集合里不允許對(duì)象有重復(fù)的值,List允許有重復(fù),它對(duì)集合中的對(duì)象進(jìn)行索引,Queue的工作原理是FCFS算法(First Come, First Serve)。

什么是HashSet

HashSet實(shí)現(xiàn)了Set接口,它不允許集合中有重復(fù)的值,當(dāng)我們提到HashSet時(shí),第一件事情就是在將對(duì)象存儲(chǔ)在HashSet之前,要先確保對(duì)象重寫equals()和hashCode()方法,這樣才能比較對(duì)象的值是否相等,以確保set中沒(méi)有儲(chǔ)存相等的對(duì)象。如果我們沒(méi)有重寫這兩個(gè)方法,將會(huì)使用這個(gè)方法的默認(rèn)實(shí)現(xiàn)。
public boolean add(Object o)方法用來(lái)在Set中添加元素,當(dāng)元素值重復(fù)時(shí)則會(huì)立即返回false,如果成功添加的話會(huì)返回true。

什么是HashMap

HashMap實(shí)現(xiàn)了Map接口,Map接口對(duì)鍵值對(duì)進(jìn)行映射。Map中不允許重復(fù)的鍵。Map接口有兩個(gè)基本的實(shí)現(xiàn),HashMap和TreeMap。TreeMap保存了對(duì)象的排列次序,而HashMap則不能。HashMap允許鍵和值為null。HashMap是非synchronized的,但collection框架提供方法能保證HashMap synchronized,這樣多個(gè)線程同時(shí)訪問(wèn)HashMap時(shí),能保證只有一個(gè)線程更改Map。
public Object put(Object Key,Object value)方法用來(lái)將元素添加到map中

HashSet和HashMap的區(qū)別

Paste_Image.png

深入了解HashMap和HashSet

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • ①HashMap的工作原理 HashMap基于hashing原理,我們通過(guò)put()和get()方法儲(chǔ)存和獲取對(duì)象...
    明教de教主閱讀 7,481評(píng)論 5 171
  • 實(shí)際上,HashSet 和 HashMap 之間有很多相似之處,對(duì)于 HashSet 而言,系統(tǒng)采用 Hash 算...
    曹振華閱讀 2,562評(píng)論 1 37
  • 1.import static是Java 5增加的功能,就是將Import類中的靜態(tài)方法,可以作為本類的靜態(tài)方法來(lái)...
    XLsn0w閱讀 1,428評(píng)論 0 2
  • Java8張圖 11、字符串不變性 12、equals()方法、hashCode()方法的區(qū)別 13、...
    Miley_MOJIE閱讀 3,899評(píng)論 0 11
  • 士為知己者死,女為悅己者容。 每每讀到后半句,我總會(huì)腦補(bǔ)這樣一幅畫面:青樓女子聞?wù)f心儀的公子來(lái)了,趕緊對(duì)著銅鏡描眉...
    老少女簌簌閱讀 815評(píng)論 2 1

友情鏈接更多精彩內(nèi)容