HashSet怎么在java中使用?相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。
專注于為中小企業(yè)提供網(wǎng)站設(shè)計、成都網(wǎng)站制作服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)潘集免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了上千企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。
Java是一門面向?qū)ο缶幊陶Z言,可以編寫桌面應(yīng)用程序、Web應(yīng)用程序、分布式系統(tǒng)和嵌入式系統(tǒng)應(yīng)用程序。
1、HashSet和TreeSet區(qū)別
HashSet底層使用Hash表。
確保元素唯一性的原理:判斷元素的hashCode值是否相同。如果是一樣的話,會繼續(xù)判斷元素的equals方法是否是true。
TreeSet底層采用紅黑樹。
確保元素的唯一性是通過Comparable或Comparator接口實現(xiàn)的。
2、HashSet和HashMap區(qū)別
事實上,HashSet的底層實現(xiàn)還是HashMap,只是它只使用了Key,具體如下:
(1)在HashSet的add方法的底層,使用HashMap的put方法將key=e,value=PRESENT構(gòu)建成key-value鍵值對,當(dāng)e存在于HashMap的key中時,value將覆蓋原來的value,但key保持不變,因此,如果在HashSet中添加了一個已經(jīng)存在的e元素,新添加的元素就不會存在于HashMap中,因此這就滿足了HashSet中元素不會重復(fù)的特性。
(2)HashSet的contains方法使用HashMap得到containsKey方法。
看完上述內(nèi)容,你們掌握HashSet怎么在java中使用的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!