排隊(duì)的時(shí)候請(qǐng)學(xué)習(xí)List 不要Set

java零基礎(chǔ)入門-高級(jí)特性篇(一)? 集合

集合框架是一個(gè)非常重要的知識(shí)點(diǎn),有了集合框架吏奸,我們?cè)谔幚硪恍┨厥獾臄?shù)據(jù)結(jié)構(gòu)的時(shí)候欢揖,可以直接用框架封裝好的工具來(lái)幫助我們解決問(wèn)題。

java對(duì)于集合框架的設(shè)計(jì)比較復(fù)雜奋蔚,但是如果我們前面的知識(shí)點(diǎn)都有掌握好她混,學(xué)起來(lái)應(yīng)該會(huì)減少很大的難度。

集合是什么

集合是用來(lái)存放對(duì)象引用的容器泊碑,對(duì)象是承載數(shù)據(jù)的載體坤按,而集合可以將對(duì)象組成各種不同的數(shù)據(jù)結(jié)構(gòu)。當(dāng)我們需要將多個(gè)數(shù)據(jù)以某一種特定的結(jié)構(gòu)進(jìn)行數(shù)據(jù)傳輸?shù)臅r(shí)候蛾狗,集合就派上用場(chǎng)了晋涣。

首先說(shuō)一下容器這個(gè)概念。我們?cè)谛陆▽?duì)象的時(shí)候沉桌,在內(nèi)存中劃分空間是隨機(jī)的谢鹊,我們不能將他們以一種方式組織起來(lái),簡(jiǎn)單的說(shuō)來(lái)就是無(wú)組織留凭,無(wú)紀(jì)律佃扼。而如果我們?cè)趦?nèi)存中直接為集合劃分一個(gè)空間,然后將對(duì)象裝入集合蔼夜,那么這些對(duì)象就是有組織兼耀,有紀(jì)律的對(duì)象。

使用集合對(duì)比

左邊是沒有容器來(lái)約束的求冷,所以對(duì)象都是隨機(jī)存儲(chǔ)瘤运。而右圖紅色部分就是在裝入對(duì)象之前,首先開辟一塊內(nèi)存給集合容器匠题,然后往容器里面存放對(duì)象拯坟,有了集合的約束,對(duì)象就會(huì)按照集合的要求來(lái)排列韭山,比如這里用的List集合容器郁季,對(duì)象就會(huì)被排列成隊(duì)列。

最常用的集合結(jié)構(gòu)有3種钱磅,List 有序隊(duì)列梦裂,Set無(wú)序隊(duì)列,Map 鍵值對(duì)盖淡。

List 有序集合

通過(guò)名字就看到了年柠,List集合是按順序存放對(duì)象的,每個(gè)對(duì)象都有自己的下標(biāo)禁舷,第一個(gè)0彪杉,第二個(gè)1毅往,以此類推。下標(biāo)不用我們?nèi)ピO(shè)置派近,而是集合本身根據(jù)添加進(jìn)來(lái)的元素自動(dòng)分配的攀唯。

有序集合

Set 無(wú)序集合

排隊(duì)是啥?不懂渴丸,往前沖就對(duì)了侯嘀。沒有先后順序,沒有任何標(biāo)記谱轨,總之把對(duì)象丟進(jìn)set以后戒幔,你就只知道他在里面,想要找到你需要的對(duì)象只能遍歷集合土童,一個(gè)個(gè)找诗茎,直到找到你想要的那個(gè)。

既然set沒有順序献汗,找起來(lái)這么麻煩敢订,那要set有什么用?set最大的特點(diǎn)就是元素不會(huì)有重復(fù)罢吃。List雖然可以保證對(duì)象有序楚午,但是無(wú)法保證集合里面的對(duì)象都不同,而set可以保證集合里面的對(duì)象都不同尿招。

無(wú)序集合

Map鍵值對(duì)

鍵值對(duì)矾柜,看名字就知道是一對(duì)一對(duì)的,一個(gè)key對(duì)應(yīng)一個(gè)value就谜,通過(guò)key去查找value怪蔑。

比如你跟你的男朋友,女朋友就是一對(duì)一對(duì)的丧荐,想要找到你饮睬,你的女朋友有一萬(wàn)種方法,比如奪命連環(huán)call啊篮奄,微信表情轟炸啊,實(shí)在不行還有手機(jī)定位大法割去。map也是一樣窟却,想要找到value,只用通過(guò)key就行呻逆,有了key就找到value了夸赫。

當(dāng)然,key是不能重復(fù)的咖城,如果已經(jīng)存在一個(gè)key茬腿,又往map里面添加一個(gè)有相同key的鍵值對(duì)呼奢,那么原來(lái)的鍵值對(duì)會(huì)被覆蓋掉,用這個(gè)key只能查到最新的value切平,而不是以前的value握础。

鍵值對(duì)

集合與數(shù)組的區(qū)別

其實(shí)說(shuō)到集合,很多同學(xué)都會(huì)想到前面說(shuō)過(guò)的一個(gè)概念 - 數(shù)組悴品。數(shù)組不是也是用來(lái)裝東西的么禀综?那用數(shù)組不是就夠了,為什么還要用集合呢苔严?

我們首先來(lái)回憶一下數(shù)組的定義方式定枷。

第一種:定義的時(shí)候就要放進(jìn)去元素,靜態(tài)初始化

int[] array = {1,2,3};

第二種:定義的時(shí)候要規(guī)定長(zhǎng)度届氢,動(dòng)態(tài)初始化

int[] array = new int[3];

好了欠窒,各位發(fā)現(xiàn)問(wèn)題沒有?要么定義的時(shí)候就要將數(shù)據(jù)準(zhǔn)備好退子,并且放進(jìn)去岖妄,要么定義的時(shí)候就要規(guī)定好數(shù)組的長(zhǎng)度。那么如果我現(xiàn)在想要一個(gè)容器來(lái)存對(duì)象絮供,但是我既不知道對(duì)象長(zhǎng)啥樣衣吠,也不知道有多少個(gè)對(duì)象會(huì)放進(jìn)去,這時(shí)候就無(wú)法使用數(shù)組來(lái)作容器了壤靶。

這種情況下缚俏,集合的作用就體現(xiàn)出來(lái)了。我只需要定義一個(gè)集合往哪一扔就夠了贮乳,不需要知道對(duì)象長(zhǎng)啥樣忧换,也不管有多少對(duì)象,來(lái)多少我往里塞多少就夠了向拆。

集合框架的結(jié)構(gòu)

集合的家族很龐大亚茬,除了上面介紹的三種常用結(jié)構(gòu)之外,還有很多結(jié)構(gòu)可以使用浓恳,下面就從集合框架的設(shè)計(jì)來(lái)逐一說(shuō)明刹缝。


1

首先,不管我們定義一個(gè)什么結(jié)構(gòu)的集合颈将,他們都有共同的特點(diǎn)梢夯,那就是可以將集合里面的元素一個(gè)個(gè)數(shù)出來(lái),也就是可以遍歷晴圾。具體怎么數(shù)我不管颂砸,能數(shù)就行。是不是很自然的想到了接口?接口定標(biāo)準(zhǔn)人乓,是個(gè)集合就能一個(gè)個(gè)數(shù)元素勤篮,所以集合體系最頂層的就是一個(gè)Iterable接口。

一個(gè)集合色罚,要能往里面放元素吧碰缔,可以刪除元素吧,對(duì)集合定義一些操作的標(biāo)準(zhǔn)保屯,這個(gè)事Collection接口干了手负,Collection接口繼承了Iterable接口,擁有了遍歷元素的標(biāo)準(zhǔn)姑尺。


2

繼續(xù)來(lái)細(xì)化標(biāo)準(zhǔn)竟终,有了操作元素的接口,就可以區(qū)分操作方式切蟋,比如通過(guò)下標(biāo)操作集合统捶,就有了List接口,沒有操作下標(biāo)功能的就成了Set接口柄粹。他們都繼承于Collection接口喘鸟,用于細(xì)化標(biāo)準(zhǔn)。


3

集合都可以有一些公共的操作驻右,比如轉(zhuǎn)為數(shù)組什黑,清空數(shù)組等操作,這時(shí)候是不是該抽象類出場(chǎng)了堪夭?抽象類實(shí)現(xiàn)公共方法給子類調(diào)用愕把,但是又有部分方法需要到具體的實(shí)現(xiàn)類才能實(shí)現(xiàn),所以使用抽象類而不是直接實(shí)現(xiàn)所有接口森爽。


4

到了這里還不能直接實(shí)現(xiàn)List和Set恨豁,因?yàn)榫退闶怯行蜿?duì)列也不止是List這一種,所以這里先安排一個(gè)抽象類來(lái)獲取集合的公共方法爬迟,方法就是繼承AbstractCollection橘蜜。然后可以實(shí)現(xiàn)大部分List和Set接口的方法了,只保留了部分特殊的方法留給子類實(shí)現(xiàn)付呕,讓最后實(shí)現(xiàn)List和Set的類有不同的功能计福。


5

最后的常用實(shí)現(xiàn)類終于登場(chǎng)了,ArrayList和HashSet是最常用的List和Set接口的實(shí)現(xiàn)徽职。通過(guò)繼承AbstractList和AbstractSet棒搜,他們獲得了抽象類的公共方法。Map也有類似的體系活箕,這里就不具體介紹了。

從以上的體系中,我們可以看到育韩,在做一個(gè)功能的時(shí)候克蚂,首先用接口定好標(biāo)準(zhǔn),然后再用接口來(lái)擴(kuò)展標(biāo)準(zhǔn)筋讨,用抽象類實(shí)現(xiàn)公共方法埃叭,再用繼承來(lái)滿足各種不同的需要形成最后使用的類。這樣來(lái)設(shè)計(jì)功能悉罕,不僅分工明確赤屋,而且靈活可變,當(dāng)需求發(fā)生變化時(shí)壁袄,可以有各種手段來(lái)擴(kuò)展功能滿足新的需求类早。

此圖不是完整的集合框架圖,只介紹了部分常用的集合以及在集合框架中的位置嗜逻。

本章帶各位大致了解了集合框架的體系結(jié)構(gòu)涩僻,這對(duì)于我們后面詳細(xì)解讀常用集合非常有用。


最近連續(xù)加班和出差栈顷,更新慢了逆日,不好意思啦各位。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末萄凤,一起剝皮案震驚了整個(gè)濱河市室抽,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌靡努,老刑警劉巖坪圾,帶你破解...
    沈念sama閱讀 218,755評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異颤难,居然都是意外死亡神年,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門行嗤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)已日,“玉大人,你說(shuō)我怎么就攤上這事栅屏∑В” “怎么了?”我有些...
    開封第一講書人閱讀 165,138評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵栈雳,是天一觀的道長(zhǎng)护奈。 經(jīng)常有香客問(wèn)我,道長(zhǎng)哥纫,這世上最難降的妖魔是什么霉旗? 我笑而不...
    開封第一講書人閱讀 58,791評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上厌秒,老公的妹妹穿的比我還像新娘读拆。我一直安慰自己,他們只是感情好鸵闪,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,794評(píng)論 6 392
  • 文/花漫 我一把揭開白布檐晕。 她就那樣靜靜地躺著,像睡著了一般蚌讼。 火紅的嫁衣襯著肌膚如雪辟灰。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,631評(píng)論 1 305
  • 那天篡石,我揣著相機(jī)與錄音芥喇,去河邊找鬼。 笑死夏志,一個(gè)胖子當(dāng)著我的面吹牛乃坤,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播沟蔑,決...
    沈念sama閱讀 40,362評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼湿诊,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了瘦材?” 一聲冷哼從身側(cè)響起厅须,我...
    開封第一講書人閱讀 39,264評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎食棕,沒想到半個(gè)月后朗和,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,724評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡簿晓,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評(píng)論 3 336
  • 正文 我和宋清朗相戀三年眶拉,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片憔儿。...
    茶點(diǎn)故事閱讀 40,040評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡忆植,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出谒臼,到底是詐尸還是另有隱情朝刊,我是刑警寧澤,帶...
    沈念sama閱讀 35,742評(píng)論 5 346
  • 正文 年R本政府宣布蜈缤,位于F島的核電站拾氓,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏底哥。R本人自食惡果不足惜咙鞍,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,364評(píng)論 3 330
  • 文/蒙蒙 一房官、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧续滋,春花似錦易阳、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,944評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)拒课。三九已至徐勃,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間早像,已是汗流浹背僻肖。 一陣腳步聲響...
    開封第一講書人閱讀 33,060評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留卢鹦,地道東北人臀脏。 一個(gè)月前我還...
    沈念sama閱讀 48,247評(píng)論 3 371
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像冀自,于是被迫代替她去往敵國(guó)和親揉稚。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,979評(píng)論 2 355

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

  • 一、集合入門總結(jié) 集合框架: Java中的集合框架大類可分為Collection和Map驻呐;兩者的區(qū)別: 1灌诅、Col...
    程序員歐陽(yáng)閱讀 11,562評(píng)論 2 61
  • Java集合類可用于存儲(chǔ)數(shù)量不等的對(duì)象,并可以實(shí)現(xiàn)常用的數(shù)據(jù)結(jié)構(gòu)如棧,隊(duì)列等,Java集合還可以用于保存具有映射關(guān)...
    小徐andorid閱讀 1,942評(píng)論 0 13
  • 今年的十月一,同樣的人潮人海含末,你是不是同樣的吃吃喝喝猜拾、轉(zhuǎn)轉(zhuǎn)玩玩?我是 旅行于我最大的意義佣盒,在于跳脫出習(xí)慣的生活軌道...
    Dr魏閱讀 278評(píng)論 0 3
  • 讀《秘密花園》有感 廈門路小學(xué) 李欣欣 《秘密花園》是上個(gè)世紀(jì)最著名的美國(guó)女作家伯內(nèi)特的...
    小茜茜公主閱讀 376評(píng)論 0 1
  • 今天把家里樓上樓下徹底打掃干凈了挎袜,我寶寶要是在家,怎么在地上玩都不會(huì)弄臟衣服沼撕。新年新氣象宋雏,期待我的小乖乖早點(diǎn)回家-...
    寒江雪810閱讀 160評(píng)論 0 0