Java中Set與List的關系與區(qū)別介紹
兩個接口都是繼承自Collection.
List (inteface)
次序是List 的最重要特點,它確保維護元素特定的順序.
--ArrayList 允許對元素快速隨機訪問.
--LinkedList 對順序訪問進行優(yōu)化,向List 中間插入與移除的開銷并不大,具有addFrist(),addLast(),getFirst,getLast,removeFirst和removeLast().這些方法使得LinkedList可當作堆棧/隊列/雙向隊列.
Set (inteface)
存入Set 的每個元素必須唯一,不保證維護元素的次序.加入Set 的Object必須定義equals()方法
--HashSet 為快速查找而設計的Set ,存入HashSet對象必須定義hashCode().
--TreeSet 保護次序的Set ,使用它可以從Set 中提取有序序列.
--LinkedHashSet 具有HashSet的查詢速度,且內部使用鏈表維護元素的次序.
它們之間的存儲方式不一樣:
TreeSet采用紅黑樹的樹據(jù)結構排序元素.
HashSet采用散列函數(shù),這是專門為快速查詢而設計的.
LinkedHashSet內部使用散列以加快查詢速度,同時使用鏈表維護元素的次序.
使用HashSet/TreeSet時,必須為類定義equals();而HashCode()是針對HashSet,作為一種編程風格,當覆蓋equals()的時候,就應該同時覆蓋hashCode().
- java中循環(huán)遍歷刪除List和Set集合中元素的方法(推薦)
- 一段代碼搞懂關于Java中List、Set集合及Map的使用
- 多用多學之Java中的Set,List,Map詳解
- Java中的Set、List、Map的用法與區(qū)別介紹
- java.lang.AbstractMethodError: org.apache.xerces.dom.DocumentImpl.setXmlVersion問題解決方法
- Java集合Set、List、Map的遍歷方法
- JAVA中l(wèi)ist,set,數(shù)組之間的轉換詳解
- Java中HashMap和Hashtable及HashSet的區(qū)別
- java.net.SocketException: Connection reset 解決方法
- JSP JavaBean的setProperty屬性
- Java Set簡介_動力節(jié)點Java學院整理
相關文章
教你如何使用Java8實現(xiàn)菜單樹形數(shù)據(jù)
今天給大家?guī)淼氖顷P于JAVA的相關知識,文中圍繞著如何使用Java8實現(xiàn)菜單樹形數(shù)據(jù)展開,文中有非常詳細的介紹及代碼示例,需要的朋友可以參考下2021-06-06SpringBoot讀取properties或者application.yml配置文件中的數(shù)據(jù)
這篇文章主要介紹了SpringBoot讀取properties或者application.yml配置文件中的數(shù)據(jù),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-06-06mybatis的動態(tài)sql之if test的使用說明
這篇文章主要介紹了mybatis的動態(tài)sql之if test的使用說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-02-02springBoot?之spring.factories擴展機制示例解析
這篇文章主要為大家介紹了springBoot?之spring.factories擴展機制示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-04-04