JDK8之Stream

JDK9今年就要發(fā)布了筑辨,而JDK8估計還有好多人沒用過,最近幾篇就簡單介紹下JDK8的一些比較有趣的用法棍辕。而本篇文章會初步介紹一下JDK8中的Stream也就是流的使用。

為什么需要 Stream

Stream 作為 Java 8 的一大亮點送矩,它與 java.io 包里的 InputStream 和 OutputStream 是完全不同的概念哪替。它也不同于 StAX 對 XML 解析的 Stream,也不是 Amazon Kinesis 對大數(shù)據(jù)實時處理的 Stream晌块。Java 8 中的 Stream 是對集合(Collection)對象功能的增強帅霜,它專注于對集合對象進行各種非常便利、高效的聚合操作(aggregate operation)身冀,或者大批量數(shù)據(jù)操作 (bulk data operation)。Stream API 借助于同樣新出現(xiàn)的 Lambda 表達式珍促,極大的提高編程效率和程序可讀性。同時它提供串行和并行兩種模式進行匯聚操作娇斩,并發(fā)模式能夠充分利用多核處理器的優(yōu)勢穴翩,使用 fork/join 并行方式來拆分任務(wù)和加速處理過程。通常編寫并行代碼很難而且容易出錯, 但使用 Stream API 無需編寫一行多線程的代碼芒帕,就可以很方便地寫出高性能的并發(fā)程序。所以說副签,Java 8 中首次出現(xiàn)的 java.util.stream 是一個函數(shù)式語言+多核時代綜合影響的產(chǎn)物。同時,理論上流的數(shù)據(jù)源可以是無限大的本砰。

從以上介紹上(摘抄自網(wǎng)上= =||)可以看出:

1钢悲、JDK8中的Stream的數(shù)據(jù)源來自集合,Stream是對集合進行操作的莺琳;

2、Stream無須顯示的編寫多線程代碼就可實現(xiàn)并行(利用fork/join框架)珍手。

下面就開始用代碼簡單展示下Stream的用法(主要與傳統(tǒng)寫法對比)辞做。

遍歷集合

遍歷集合是對集合最常見的操作了

首先是傳統(tǒng)寫法:

然后是Stream寫法:

集合的遍歷看起來似乎并沒有什么太大區(qū)別秤茅,都是三行,下面換一個復(fù)雜的場景

求最大值(集合中都是int類型的值)

傳統(tǒng)寫法:

Stream寫法:

此時Stream的優(yōu)勢就顯而易見了课幕,首先是代碼的縮減,最主要的是語義上比第一個要清晰多了(至少我這么認為O(∩_∩)O哈哈哈~)

數(shù)據(jù)過濾:

數(shù)據(jù)過濾也是常用的操作之一粪般,下面通過過濾集合中大于10的數(shù)來比較一下傳統(tǒng)寫法和Stream寫法的差別污桦。

傳統(tǒng)寫法:

Stream寫法:

數(shù)據(jù)轉(zhuǎn)換

數(shù)據(jù)的轉(zhuǎn)換也是很常見的對集合的操作凡橱,下面示范一下將集合中的字符串轉(zhuǎn)成數(shù)字的操作(集合中的字符串都是數(shù)字)。

首先是傳統(tǒng)操作:

Stream操作:

可以看出這個操作也是很簡潔的顾稀。

除了以上幾種操作外流還能完成許多事情(許多數(shù)據(jù)庫的操作流也都可以完成)静秆,各位自己可以嘗試一下。另外需要注意的是抚笔,默認流是串行操作的侨拦,除非自己指定需要并行操作。

獲取流的途徑:

Collection.stream()-->串行流

Collection.parallelStream()-->并行流

Arrays.stream(T array) or Stream.of()-->串行流

java.util.stream.IntStream.range()-->串行流

.......

除了以上列出的幾種外還有其他的方式膨蛮,不過常用的就這幾種了季研,能滿足日常大部分需求了。

JDK8中Stream的使用就簡單介紹到此与涡,各位下去可以自己嘗試著使用一下,當(dāng)你習(xí)慣后相信你會愛上這種寫法的豺鼻,真心好使~~

如果對文章內(nèi)容有任何疑問請加QQ1213812243细睡。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末球化,一起剝皮案震驚了整個濱河市夕土,隨后出現(xiàn)的幾起案子井誉,更是在濱河造成了極大的恐慌,老刑警劉巖喳钟,帶你破解...
    沈念sama閱讀 216,470評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件在岂,死亡現(xiàn)場離奇詭異,居然都是意外死亡易茬,警方通過查閱死者的電腦和手機及老,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,393評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來食铐,“玉大人叠蝇,你說我怎么就攤上這事』诖罚” “怎么了单芜?”我有些...
    開封第一講書人閱讀 162,577評論 0 353
  • 文/不壞的土叔 我叫張陵洲鸠,是天一觀的道長。 經(jīng)常有香客問我扒腕,道長,這世上最難降的妖魔是什么皆的? 我笑而不...
    開封第一講書人閱讀 58,176評論 1 292
  • 正文 為了忘掉前任蹋盆,我火速辦了婚禮硝全,結(jié)果婚禮上楞抡,老公的妹妹穿的比我還像新娘。我一直安慰自己凳厢,他們只是感情好竞慢,可當(dāng)我...
    茶點故事閱讀 67,189評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著泡孩,像睡著了一般寺谤。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上变屁,一...
    開封第一講書人閱讀 51,155評論 1 299
  • 那天粟关,我揣著相機與錄音,去河邊找鬼闷板。 笑死,一個胖子當(dāng)著我的面吹牛遮晚,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播县遣,決...
    沈念sama閱讀 40,041評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼萧求,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了夸政?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,903評論 0 274
  • 序言:老撾萬榮一對情侶失蹤法绵,失蹤者是張志新(化名)和其女友劉穎朋譬,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體徙赢,經(jīng)...
    沈念sama閱讀 45,319評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,539評論 2 332
  • 正文 我和宋清朗相戀三年窑业,在試婚紗的時候發(fā)現(xiàn)自己被綠了枕屉。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,703評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡西潘,死狀恐怖哨颂,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情品姓,我是刑警寧澤箫措,帶...
    沈念sama閱讀 35,417評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站馏谨,受9級特大地震影響附迷,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜喇伯,卻給世界環(huán)境...
    茶點故事閱讀 41,013評論 3 325
  • 文/蒙蒙 一拨与、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧捻悯,春花似錦、人聲如沸今缚。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,664評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽何荚。三九已至,卻和暖如春妥衣,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背税手。 一陣腳步聲響...
    開封第一講書人閱讀 32,818評論 1 269
  • 我被黑心中介騙來泰國打工稠鼻, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人熙暴。 一個月前我還...
    沈念sama閱讀 47,711評論 2 368
  • 正文 我出身青樓慌盯,卻偏偏與公主長得像,于是被迫代替她去往敵國和親亚皂。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,601評論 2 353

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