小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

List和Set的差別

 520jefferson 2014-03-17
兩個接口都是繼承自Collection. 

List (inteface) 

次序是List 的最重要特點(diǎn),它確保維護(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().

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點(diǎn)擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多