集合概述

1 數(shù)組和集合區(qū)別

在這里插入圖片描述

2. 集合常見的方法

在這里插入圖片描述

3. 常用集合分類

3.1 Collection接口下的

  • List接口
    • LinkList:鏈表, 插入刪除憔购, 沒有同步, 線程不安全
    • ArrayList: 數(shù)組, 隨機訪問, 沒有同步侨舆, 線程不安全
    • Vector:數(shù)組秒紧, 同步, 線程安全
  • Set接口
    • HashSet:底層數(shù)據(jù)結(jié)構(gòu)是哈希表(是一個元素為鏈表的數(shù)組)
    • TreeSet:底層數(shù)據(jù)結(jié)構(gòu)是紅黑樹(是一個自平衡的二叉樹)
    • LinkedHashSet:底層數(shù)據(jù)結(jié)構(gòu)由哈希表和鏈表組成挨下。

3.2 Map接口下的

  • HashTable:同步熔恢, 線程安全
  • HashMap:沒有同步, 線程不安全-
  • TreeMap:紅黑樹對所有的key進行排序
  • IdentifyHashMap

4. List和set的區(qū)別

  • 重復(fù)元素:list可以允許重復(fù)元素,set不允許
  • 有序性:list是一個有序的容器复颈,保持了每個元素的插入順序绩聘。即輸出順序就是輸入順序沥割,而set方法是無序容器耗啦,無法保證每個元素的存儲順序,TreeSet通過 Comparator 或者 Comparable 維護了一個排序順序
  • null元素:list可以插入多個null元素,而set只允許插入一個null元素

5. 迭代器(Iterator)

Collection的源碼中繼承了Iterable机杜,有iterator()這個方法

在這里插入圖片描述

Iterable是一個接口帜讲,它有iterator()這個方法,返回的是Iterator

Iterator也是一個接口椒拗,它只有四個方法:

  • hasNext()
  • next()
  • remove()
  • forEachRemaining()
在這里插入圖片描述

在ArrayList內(nèi)部首先是定義一個內(nèi)部類Itr似将,該內(nèi)部類實現(xiàn)Iterator接口,如下:

在這里插入圖片描述

而ArrayList的iterator()方法實現(xiàn)

public Iterator<E> iterator() {
    return new Itr();
}

Iterator(迭代器)是一個接口蚀苛,它的作用就是遍歷容器的所有元素在验。

ArrayList<String> arrayList = new ArrayList<>();
Iterator<String> iterator = arrayList.iterator();

Iterator的意義

遍歷ArrayList 和Linklist是十分容易的,遍歷Tree容器也不難堵未,但是實現(xiàn)機制是完全不同腋舌,而遍歷Set容器就無從下手了。 所以Java設(shè)計了Iterator 這個接口渗蟹,分別讓各種容器自己去重寫里面的hasNext()和next()方法块饺。不用關(guān)心各種容器的遍歷機制,只要使用Iterator雌芽,會讓人覺得各種容器的遍歷方法都是一樣的授艰,這就是Java接口的重要意義。

幾個遍歷的比較

  • for一般可以用于簡單的順序集合世落,并且可以預(yù)測集合的大谢刺凇;
  • foreach可以遍歷任何集合或者數(shù)組屉佳,但是使用者需要知道遍歷元素的類型谷朝。
  • iterator是最強大的,它可以隨之修改元素內(nèi)部的元素忘古∨墙可以在遍歷的時刻用remove()
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市髓堪,隨后出現(xiàn)的幾起案子送朱,更是在濱河造成了極大的恐慌娘荡,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,265評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件驶沼,死亡現(xiàn)場離奇詭異炮沐,居然都是意外死亡,警方通過查閱死者的電腦和手機回怜,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,078評論 2 385
  • 文/潘曉璐 我一進店門大年,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人玉雾,你說我怎么就攤上這事翔试。” “怎么了复旬?”我有些...
    開封第一講書人閱讀 156,852評論 0 347
  • 文/不壞的土叔 我叫張陵垦缅,是天一觀的道長。 經(jīng)常有香客問我驹碍,道長壁涎,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,408評論 1 283
  • 正文 為了忘掉前任志秃,我火速辦了婚禮怔球,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘浮还。我一直安慰自己竟坛,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 65,445評論 5 384
  • 文/花漫 我一把揭開白布碑定。 她就那樣靜靜地躺著流码,像睡著了一般。 火紅的嫁衣襯著肌膚如雪延刘。 梳的紋絲不亂的頭發(fā)上漫试,一...
    開封第一講書人閱讀 49,772評論 1 290
  • 那天,我揣著相機與錄音碘赖,去河邊找鬼驾荣。 笑死,一個胖子當(dāng)著我的面吹牛普泡,可吹牛的內(nèi)容都是我干的播掷。 我是一名探鬼主播,決...
    沈念sama閱讀 38,921評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼撼班,長吁一口氣:“原來是場噩夢啊……” “哼歧匈!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起砰嘁,我...
    開封第一講書人閱讀 37,688評論 0 266
  • 序言:老撾萬榮一對情侶失蹤件炉,失蹤者是張志新(化名)和其女友劉穎勘究,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體斟冕,經(jīng)...
    沈念sama閱讀 44,130評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡口糕,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,467評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了磕蛇。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片景描。...
    茶點故事閱讀 38,617評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖秀撇,靈堂內(nèi)的尸體忽然破棺而出超棺,到底是詐尸還是另有隱情,我是刑警寧澤捌袜,帶...
    沈念sama閱讀 34,276評論 4 329
  • 正文 年R本政府宣布说搅,位于F島的核電站炸枣,受9級特大地震影響虏等,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜适肠,卻給世界環(huán)境...
    茶點故事閱讀 39,882評論 3 312
  • 文/蒙蒙 一霍衫、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧侯养,春花似錦敦跌、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,740評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至辩稽,卻和暖如春惧笛,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背逞泄。 一陣腳步聲響...
    開封第一講書人閱讀 31,967評論 1 265
  • 我被黑心中介騙來泰國打工患整, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人喷众。 一個月前我還...
    沈念sama閱讀 46,315評論 2 360
  • 正文 我出身青樓各谚,卻偏偏與公主長得像,于是被迫代替她去往敵國和親到千。 傳聞我的和親對象是個殘疾皇子昌渤,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,486評論 2 348

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

  • 前言 大部分編程語言都提供了數(shù)組來保存對象,數(shù)組是非常重要的數(shù)據(jù)結(jié)構(gòu)之一憔四。但是數(shù)組在初始化時就已經(jīng)定義了數(shù)組長度膀息,...
    海人為記閱讀 490評論 0 1
  • 面向?qū)ο笳Z言對事物的體現(xiàn)都是以對象的形式望抽,為了方便對多個對象的操作,就要對對象進行存儲履婉。另一方面煤篙,使用Array存...
    Martain閱讀 137評論 0 1
  • List集合序列排序方法①集合中是簡單整型 輸出為:1 2 3②集合中為對象 實體類要實現(xiàn)Comparable接口...
    Anwfly閱讀 265評論 0 0
  • 概述 我們都知道,數(shù)組的長度是不可變的, 當(dāng)元素的個數(shù)超過數(shù)組的長度之后, 我們就只能通過創(chuàng)建長度更長的新數(shù)組的方...
    778778閱讀 222評論 0 0
  • 夜鶯2517閱讀 127,717評論 1 9