Java集合之遍歷

在Java開(kāi)發(fā)中询件,集合唆樊,可以說(shuō)使我們必然要使用到的一個(gè)框架。對(duì)集合的遍歷也是我么經(jīng)常要進(jìn)行的操作嘿辟,而遍歷操作又有多種,下面就對(duì)集合遍歷進(jìn)行以下總結(jié)英古。

一昙读、List、Set的遍歷

List與Set都繼承了Collection接口蛮浑,從某種程度上來(lái)說(shuō)可以將List和Set看作同一種類型,因此對(duì)于他們的遍歷方式也是相同的艺沼。

下面以List為例進(jìn)行講述
List<String> lists = new ArrayList<>();
lists.add("A");
lists.add("B");
lists.add("C");
lists.add("D");
lists.add("E");
lists.add("F");

方式一:

普通for循環(huán)

for (int i = 0; i < lists.size(); i++){
    System.out.println(lists.get(i));
}

當(dāng)然這種方式對(duì)于Set集合是不適用的壮虫,因?yàn)镾et集合中并沒(méi)有g(shù)et index方法。

方式二:

for-each循環(huán)

for(String s : lists){
    System.out.println(s);
}

對(duì)于這種方式的遍歷剩拢,是會(huì)存在一些問(wèn)題的饶唤。首先,每次遍歷集合類時(shí)办素,都需要寫(xiě)很多樣板代碼祸穷,對(duì)遍歷進(jìn)行改造也很麻煩,需要修改每一個(gè)for循環(huán)雷滚。并且這樣做也模糊了代碼的本意祈远,需閱讀完整個(gè)循環(huán)體才能理解這段代碼的意圖,無(wú)形當(dāng)中增加了時(shí)間成本车份。

方式三:

使用Iterator外部迭代

Iterator<String> iterator = lists.iterator();
while(iterator.hasNext()){
    System.out.println(iterator.next());
}

方式四:

使用Iterator迭代

for (Iterator iterator = lists.iterator(); iterator.hasNext();)
{
    String string = (String) iterator.next();           
}

實(shí)際上方式四和方式三是類似的,區(qū)別只不過(guò)是方式三使用while循環(huán)扫沼,方式四使用for循環(huán)庄吼。
并且從內(nèi)部來(lái)說(shuō)方式二(for-each循環(huán))與方式三以政、方式四(Iterator遍歷)其實(shí)是相同的,屬于外部迭代废菱,只是形式不同抖誉。for-each其實(shí)是一個(gè)封裝了迭代的語(yǔ)法糖。
但從性能上來(lái)說(shuō)袒炉,使用Iterator性能會(huì)更好些我磁。
總體上說(shuō),無(wú)論是for-each循環(huán)還是迭代器遍歷都會(huì)將行為和方法混為一談夺艰,很難抽象出各種不同的操作。

方式五:

Stream內(nèi)部迭代

List<String> lists = new ArrayList<String>();
lists.add("A");
lists.add("B");
lists.add("Ct");
lists.add("Dt");
lists.add("Et");
lists.add("Ft");
long count = lists.stream().filter(new Predicate<String>(){
    @Override
    public boolean test(String t){
        return t.endsWith("t");
    }
}).count();
System.out.println(count);

在這里我們過(guò)濾出以"t"結(jié)尾的字符串减牺,并打印出這樣字符串的個(gè)數(shù)存谎。
這是Java8新出來(lái)的一個(gè)類,Stream使用函數(shù)式編程的方式在集合類上進(jìn)行復(fù)雜操作的工具稚失。我們可以通過(guò)這種流機(jī)制恰聘、Stream類中的各種操作符以及Java中的函數(shù)接口去做任何我們想做的事情,并且代碼的可讀性也大大提高诫钓。

二篙螟、Map的遍歷

Map<Integer, String> maps = new HashMap<Integer, String>();
maps.put(1, "A");
maps.put(2, "B");
maps.put(3, "C");
maps.put(4, "D");
maps.put(5, "E");

方式一:

for-each單獨(dú)遍歷key和value

//遍歷keys
for(Integer key : maps.keySet()){
    System.out.println(key);
}
//遍歷values
for(String value : maps.values()){
    System.out.println(value);
}

方式二:

先遍歷keys问拘,然后通過(guò)key查找值

for(Integer key : maps.keySet()){
    String value = maps.get(key);
    System.out.println(key+":"+value);
}

方式三:

通過(guò)Entry進(jìn)行遍歷

for (Map.Entry<Integer, String> entry : maps.entrySet()){
    Integer key = entry.getKey();//獲取key
    String value = entry.getValue();//獲取value
    System.out.println(key + ":" + value);
}

方式四:

使用迭代器進(jìn)行遍歷

Iterator<Map.Entry<Integer, String>> iterator = maps.entrySet().iterator();
while (iterator.hasNext()){
    Map.Entry<Integer, String> entry = iterator.next();
    Integer key = entry.getKey();//獲取key
    String value = entry.getValue();//獲取value
}
四種遍歷方式的比較

在這四種方式中,方式二是效率最低的一種方式绪杏,因?yàn)閺膹逆I取值的get方法是耗時(shí)的操作,所以并不推薦使用此方式势似。
方式一在性能上比方式三要好一些僧著,并且方式一的代碼更加干凈易讀。
在性能方面盹愚,方式四與方式一可以說(shuō)是相同的皆怕。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市憋活,隨后出現(xiàn)的幾起案子顶滩,更是在濱河造成了極大的恐慌,老刑警劉巖礁鲁,帶你破解...
    沈念sama閱讀 216,372評(píng)論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件仅醇,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡析二,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)蛤吓,“玉大人,你說(shuō)我怎么就攤上這事锅棕。” “怎么了裸燎?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,415評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵德绿,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我移稳,道長(zhǎng),這世上最難降的妖魔是什么袱蚓? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,157評(píng)論 1 292
  • 正文 為了忘掉前任几蜻,我火速辦了婚禮,結(jié)果婚禮上颖低,老公的妹妹穿的比我還像新娘弧烤。我一直安慰自己,他們只是感情好暇昂,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布急波。 她就那樣靜靜地躺著,像睡著了一般澄暮。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上伸辟,一...
    開(kāi)封第一講書(shū)人閱讀 51,125評(píng)論 1 297
  • 那天馍刮,我揣著相機(jī)與錄音,去河邊找鬼忙迁。 笑死碎乃,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的恰梢。 我是一名探鬼主播,決...
    沈念sama閱讀 40,028評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼嵌言,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼及穗!你這毒婦竟也來(lái)了埂陆?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 38,887評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤购裙,失蹤者是張志新(化名)和其女友劉穎鹃栽,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體民鼓,經(jīng)...
    沈念sama閱讀 45,310評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡丰嘉,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評(píng)論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了黄娘。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片克滴。...
    茶點(diǎn)故事閱讀 39,690評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖誓焦,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情杂伟,我是刑警寧澤,帶...
    沈念sama閱讀 35,411評(píng)論 5 343
  • 正文 年R本政府宣布观话,位于F島的核電站越平,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏晦溪。R本人自食惡果不足惜挣跋,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評(píng)論 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望嫌术。 院中可真熱鬧牌借,春花似錦、人聲如沸膨报。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)够吩。三九已至,卻和暖如春周循,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背饮怯。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,812評(píng)論 1 268
  • 我被黑心中介騙來(lái)泰國(guó)打工嚎研, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人论矾。 一個(gè)月前我還...
    沈念sama閱讀 47,693評(píng)論 2 368
  • 正文 我出身青樓贪壳,卻偏偏與公主長(zhǎng)得像饱亿,于是被迫代替她去往敵國(guó)和親寥袭。 傳聞我的和親對(duì)象是個(gè)殘疾皇子关霸,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評(píng)論 2 353

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

  • 1.Java集合框架是什么队寇?說(shuō)出一些集合框架的優(yōu)點(diǎn)? 每種編程語(yǔ)言中都有集合佳遣,最初的Java版本包含幾種集合類:V...
    獨(dú)念白閱讀 768評(píng)論 0 2
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語(yǔ)法零渐,類相關(guān)的語(yǔ)法尺锚,內(nèi)部類的語(yǔ)法隙袁,繼承相關(guān)的語(yǔ)法幌墓,異常的語(yǔ)法铸鹰,線程的語(yǔ)...
    子非魚(yú)_t_閱讀 31,622評(píng)論 18 399
  • Collection接口 Collection接口是所有集合的祖先類戒财。他有兩個(gè)構(gòu)造方法,一個(gè)無(wú)參構(gòu)造饮寞,一個(gè)是帶Co...
    夜幕繁華閱讀 591評(píng)論 0 0
  • UX標(biāo)記 Fuse主要被用來(lái)做這么兩類事兒: 一類是用來(lái)創(chuàng)建App或者原型幽崩,主要是編寫(xiě)跨平臺(tái)的JavaScript...
    衣咸閱讀 325評(píng)論 0 0
  • 夢(mèng)到你一次又一次 嘿嘿,在夢(mèng)里都不相信你了
    戲精w閱讀 156評(píng)論 0 0