Java集合中List,Set以及Map等集合體系詳解

List , Set, Map都是接口,前兩個(gè)繼承至collection接口继阻,Map為獨(dú)立接口

Set下有HashSet,LinkedHashSet废酷,TreeSet

List下有ArrayList瘟檩,Vector,LinkedList

Map下有Hashtable澈蟆,LinkedHashMap墨辛,HashMap,TreeMap

collection接口下還有個(gè)Queue接口趴俘,有PriorityQueue類


注意:

Queue接口與List睹簇、Set同一級別奏赘,都是繼承了collection接口。

看圖你會(huì)發(fā)現(xiàn),LinkedList既可以實(shí)現(xiàn)Queue接口,也可以實(shí)現(xiàn)List接口.只不過呢, LinkedList實(shí)現(xiàn)了Queue接口太惠。Queue接口窄化了對LinkedList的方法的訪問權(quán)限(即在方法中的參數(shù)類型如果是Queue時(shí)志珍,就完全只能訪問Queue接口所定義的方法 了,而不能直接訪問 LinkedList的非Queue的方法)垛叨,以使得只有恰當(dāng)?shù)姆椒ú趴梢允褂谩?/p>

SortedSet是個(gè)接口伦糯,它里面的(只有TreeSet這一個(gè)實(shí)現(xiàn)可用)中的元素一定是有序的。

總結(jié):

connection接口(注意首字母小寫):

— List 有序,可重復(fù)

ArrayList

優(yōu)點(diǎn): 底層數(shù)據(jù)結(jié)構(gòu)是數(shù)組嗽元,查詢快敛纲,增刪慢。

缺點(diǎn): 線程不安全剂癌,效率高

Vector

優(yōu)點(diǎn): 底層數(shù)據(jù)結(jié)構(gòu)是數(shù)組淤翔,查詢快,增刪慢佩谷。

缺點(diǎn): 線程安全旁壮,效率低

LinkedList

優(yōu)點(diǎn): 底層數(shù)據(jù)結(jié)構(gòu)是鏈表,查詢慢谐檀,增刪快抡谐。

缺點(diǎn): 線程不安全,效率高

—Set 無序,唯一

HashSet

底層數(shù)據(jù)結(jié)構(gòu)是哈希表桐猬。(無序,唯一)

如何來保證元素唯一性?

1.依賴兩個(gè)方法:hashCode()和equals()

LinkedHashSet

底層數(shù)據(jù)結(jié)構(gòu)是鏈表和哈希表麦撵。(FIFO插入有序,唯一)

1.由鏈表保證元素有序

2.由哈希表保證元素唯一

TreeSet

底層數(shù)據(jù)結(jié)構(gòu)是紅黑樹。(唯一溃肪,有序)

1. 如何保證元素排序的呢?

自然排序

比較器排序

2.如何保證元素唯一性的呢?

根據(jù)比較的返回值是否是0來決定

針對collection集合我們到底使用誰呢?(掌握)

唯一嗎?

是:Set

排序嗎?

是:TreeSet或LinkedHashSet

否:HashSet

如果你知道是Set免胃,但是不知道是哪個(gè)Set,就用HashSet惫撰。

否:List

要安全嗎?

是:Vector

否:ArrayList或者LinkedList

查詢多:ArrayList

增刪多:LinkedList

如果你知道是List羔沙,但是不知道是哪個(gè)List,就用ArrayList厨钻。

如果你知道是collection集合扼雏,但是不知道使用誰,就用ArrayList莉撇。

如果你知道用集合呢蛤,就用ArrayList惶傻。

說完了collection,來簡單說一下Map.

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末棍郎,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子银室,更是在濱河造成了極大的恐慌涂佃,老刑警劉巖励翼,帶你破解...
    沈念sama閱讀 206,378評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異辜荠,居然都是意外死亡汽抚,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,356評論 2 382
  • 文/潘曉璐 我一進(jìn)店門伯病,熙熙樓的掌柜王于貴愁眉苦臉地迎上來造烁,“玉大人,你說我怎么就攤上這事午笛〔洋” “怎么了?”我有些...
    開封第一講書人閱讀 152,702評論 0 342
  • 文/不壞的土叔 我叫張陵药磺,是天一觀的道長告组。 經(jīng)常有香客問我,道長癌佩,這世上最難降的妖魔是什么木缝? 我笑而不...
    開封第一講書人閱讀 55,259評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮围辙,結(jié)果婚禮上我碟,老公的妹妹穿的比我還像新娘。我一直安慰自己姚建,他們只是感情好怎囚,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,263評論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著桥胞,像睡著了一般恳守。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上贩虾,一...
    開封第一講書人閱讀 49,036評論 1 285
  • 那天催烘,我揣著相機(jī)與錄音,去河邊找鬼缎罢。 笑死伊群,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的策精。 我是一名探鬼主播舰始,決...
    沈念sama閱讀 38,349評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼咽袜!你這毒婦竟也來了丸卷?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 36,979評論 0 259
  • 序言:老撾萬榮一對情侶失蹤询刹,失蹤者是張志新(化名)和其女友劉穎谜嫉,沒想到半個(gè)月后萎坷,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,469評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡沐兰,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,938評論 2 323
  • 正文 我和宋清朗相戀三年哆档,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片住闯。...
    茶點(diǎn)故事閱讀 38,059評論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡瓜浸,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出比原,到底是詐尸還是另有隱情斟叼,我是刑警寧澤,帶...
    沈念sama閱讀 33,703評論 4 323
  • 正文 年R本政府宣布春寿,位于F島的核電站朗涩,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏绑改。R本人自食惡果不足惜谢床,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,257評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望厘线。 院中可真熱鬧识腿,春花似錦、人聲如沸造壮。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,262評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽耳璧。三九已至成箫,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間旨枯,已是汗流浹背蹬昌。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留攀隔,地道東北人皂贩。 一個(gè)月前我還...
    沈念sama閱讀 45,501評論 2 354
  • 正文 我出身青樓,卻偏偏與公主長得像昆汹,于是被迫代替她去往敵國和親明刷。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,792評論 2 345

推薦閱讀更多精彩內(nèi)容