Java中Set與List的關(guān)系與區(qū)別介紹
兩個接口都是繼承自Collection.
List (inteface)
次序是List 的最重要特點,它確保維護(hù)元素特定的順序.
--ArrayList 允許對元素快速隨機(jī)訪問.
--LinkedList 對順序訪問進(jìn)行優(yōu)化,向List 中間插入與移除的開銷并不大,具有addFrist(),addLast(),getFirst,getLast,removeFirst和removeLast().這些方法使得LinkedList可當(dāng)作堆棧/隊列/雙向隊列.
Set (inteface)
存入Set 的每個元素必須唯一,不保證維護(hù)元素的次序.加入Set 的Object必須定義equals()方法
--HashSet 為快速查找而設(shè)計的Set ,存入HashSet對象必須定義hashCode().
--TreeSet 保護(hù)次序的Set ,使用它可以從Set 中提取有序序列.
--LinkedHashSet 具有HashSet的查詢速度,且內(nèi)部使用鏈表維護(hù)元素的次序.
它們之間的存儲方式不一樣:
TreeSet采用紅黑樹的樹據(jù)結(jié)構(gòu)排序元素.
HashSet采用散列函數(shù),這是專門為快速查詢而設(shè)計的.
LinkedHashSet內(nèi)部使用散列以加快查詢速度,同時使用鏈表維護(hù)元素的次序.
使用HashSet/TreeSet時,必須為類定義equals();而HashCode()是針對HashSet,作為一種編程風(fēng)格,當(dāng)覆蓋equals()的時候,就應(yīng)該同時覆蓋hashCode().
- java中循環(huán)遍歷刪除List和Set集合中元素的方法(推薦)
- 一段代碼搞懂關(guān)于Java中List、Set集合及Map的使用
- 多用多學(xué)之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ù)組之間的轉(zhuǎn)換詳解
- Java中HashMap和Hashtable及HashSet的區(qū)別
- java.net.SocketException: Connection reset 解決方法
- JSP JavaBean的setProperty屬性
- Java Set簡介_動力節(jié)點Java學(xué)院整理
相關(guān)文章
eclipse實現(xiàn)ElGamal數(shù)字簽名
這篇文章主要為大家詳細(xì)介紹了eclipse實現(xiàn)ElGamal數(shù)字簽名,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-06-06
Java中Map轉(zhuǎn)List及List轉(zhuǎn)Map的方法(簡單好用!)
這篇文章主要給大家介紹了關(guān)于Java中Map轉(zhuǎn)List及List轉(zhuǎn)Map的相關(guān)資料,可以使用Java 8的Stream API將Java Map轉(zhuǎn)換為List,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-07-07
SpringBoot接口參數(shù)的默認(rèn)值與必要性最佳實踐記錄
這篇文章主要介紹了SpringBoot接口參數(shù)的默認(rèn)值與必要性,通過合理設(shè)置接口參數(shù)的默認(rèn)值和必要性,我們可以創(chuàng)建出既健壯又靈活的?RESTful?API,需要的朋友可以參考下2024-08-08

