国产一区二区精品-国产一区二区精品久-国产一区二区精品久久-国产一区二区精品久久91-免费毛片播放-免费毛片基地

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > set有哪些實現類?

set有哪些實現類?

來源:千鋒教育
發布人:qyf
時間: 2022-08-01 17:04:59 1659344699

set有哪些實現類

  HashSet

  HashSet是set接口的實現類,set下面最主要的實現類就是HashSet(也就是用的最多的),此外還有LinkedHashSet和TreeSet。

  HashSet是無序的、不可重復的。通過對象的hashCode和equals方法保證對象的唯一性。

  HashSet內部的存儲結構是哈希表,是線程不安全的。

  TreeSet

  TreeSet對元素進行排序的方式:

  元素自身具備比較功能,需要實現Comparable接口,并覆蓋compareTo方法。

  元素自身不具備比較功能,需要實現Comparator接口,并覆蓋compare方法。

  LinkedHashSet

  LinkedHashSet是一種有序的Set集合,即其元素的存入和輸出的順序是相同的。

  說一下 HashSet 的實現原理?

  HashSet實際上是一個HashMap實例,數據存儲結構都是數組+鏈表。

  HashSet是基于HashMap實現的,HashSet中的元素都存放在HashMap的key上面,而value都是一個統一的對象PRESENT。

  private static final Object PRESENT = new Object();

  HashSet中add方法調用的是底層HashMap中的put方法,put方法要判斷插入值是否存在,而HashSet的add方法,首先判斷元素是否存在,如果存在則插入,如果不存在則不插入,這樣就保證了HashSet中不存在重復值。

  通過對象的hashCode和equals方法保證對象的唯一性。

  ArrayList 和 LinkedList 的區別是什么?

  ArrayList是動態數組的數據結構實現,查找和遍歷的效率較高。

  LinkedList 是雙向鏈表的數據結構,增加和刪除的效率較高。

  更多關于“Java培訓”的問題,歡迎咨詢千鋒教育在線名師。千鋒已有十余年的培訓經驗,課程大綱更科學更專業,有針對零基礎的就業班,有針對想提升技術的好程序員班,高品質課程助力你實現java程序員夢想。

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT