Stream詳解

Java 8引入了全新的Stream API潮孽。這里的Stream和I/O流不同,它更像具有Iterable的集合類,但行為和集合類又有所不同.

我們先來看看Java里面是怎么定義Stream的:

A sequence of elements supporting sequential and parallel aggregate operations.

我們來解讀一下上面的那句話:

Stream是元素的集合,這點讓Stream看起來用些類似Iterator;
可以支持順序和并行的對原Stream進行匯聚的操作硅蹦;

Stream<T>接口繼承自BaseStream<T, S extends BaseStream<T, S>>,而BaseStream接口則是Stream的基本定義接口.

BaseStream的核心接口方法:

  • Iterator<T> iterator();

    表明Stream能夠進行迭代操作

  • Spliterator<T> spliterator();

    表明Stream能夠進行分割迭代

  • boolean isParallel();

    判斷Stream是否是并行的Stream

  • S sequential();

    獲取串行的Stream

  • S parallel();

    獲取并行的Stream

  • S unordered();

    獲取無序的Stream

  • S onClose(Runnable closeHandler);

    返回一個同樣的Stream,并同時執(zhí)行一個Runnable

而Stream<T>繼承了BaseStream<T, Stream<T>,則說明Stream具有BaseStream接口中所描述的方法的能力. 并且Stream對其進行了擴展,如果說BaseStream只是定義了流(Stream)具有哪些能力,則Stream接口則定義了一個具體的流能做哪些事情.

以下是Stream的的核心接口方法:

  • Stream<T> filter(Predicate<? super T> predicate)

    在Stream中過濾符合指定條件的元素

  • <R> Stream<R> map(Function<? super T, ? extends R> mapper)

    將Stream中的元素轉換成另一種數據格式

  • IntStream mapToInt(ToIntFunction<? super T> mapper)

    將Stream中的元素轉換成int類型的值

  • LongStream mapToLong(ToLongFunction<? super T> mapper)

    將Stream中的元素轉換成long類型的值

  • DoubleStream mapToDouble(ToDoubleFunction<? super T> mapper)

    將Stream中的元素轉換成double類型的值

  • <R> Stream<R> flatMap(Function<? super T, ? extends Stream<? extends R>> mapper)

    將stream中的元素轉換成stream

  • IntStream flatMapToInt(Function<? super T, ? extends IntStream> mapper)

    將stream中的元素轉換成int類型的stream

  • LongStream flatMapToLong(Function<? super T, ? extends LongStream> mapper)

    將stream中的元素轉換成long類型的stream    
    
  • DoubleStream flatMapToDouble(Function<? super T, ? extends DoubleStream> mapper)

    將stream中的元素轉換成double類型的stream

  • Stream<T> distinct()

    將Stream中重復的元素去除掉

  • Stream<T> sorted()

    對Stream中的元素進行排序

  • Stream<T> sorted(Comparator<? super T> comparator)

對Stream中的元素進行指定比較器進行排序

  • Stream<T> peek(Consumer<? super T> action)

    對Stream中的元素都調用指定的方法,不影響原有元素內容

  • Stream<T> limit(long maxSize)

    限制Stream的元素內容的大小

  • Stream<T> skip(long n)

    獲取跳過指定長度的Stream

  • void forEach(Consumer<? super T> action)

    遍歷處理Stream中的元素

  • void forEachOrdered(Consumer<? super T> action)

    按照順序遍歷處理Stream中的元素

  • Object[] toArray()

    將Stream轉換成對象數組

  • <A> A[] toArray(IntFunction<A[]> generator)

    將Stream 轉換成指定對象的數組

  • T reduce(T identity, BinaryOperator<T> accumulator)

    對Stream進行規(guī)約操作

  • Optional<T> reduce(BinaryOperator<T> accumulator)

    對Stream進行規(guī)約操作
    
  • <U> U reduce(U identity,
    BiFunction<U, ? super T, U> accumulator,
    BinaryOperator<U> combiner)

對Stream進行規(guī)約操作

  • <R> R collect(Supplier<R> supplier,
    BiConsumer<R, ? super T> accumulator,
    BiConsumer<R, R> combiner)

    通過指定的收集器,收集Stream的內容
    
  • <R, A> R collect(Collector<? super T, A, R> collector)

    通過指定的收集器,收集Stream的內容

  • Optional<T> min(Comparator<? super T> comparator)

    通過指定的比較器獲取元素的最小值

  • Optional<T> max(Comparator<? super T> comparator)

通過指定的比較器獲取元素的最大值

  • long count()

獲取Stream的元素內容大小

  • boolean anyMatch(Predicate<? super T> predicate)

    判斷Stream中是否含有指定要求的元素

  • boolean allMatch(Predicate<? super T> predicate)

    判斷Stream中所有元素是否符合指定要求

  • boolean noneMatch(Predicate<? super T> predicate)

    判斷Stream中所有元素是否都不符合指定要求

  • Optional<T> findFirst()

    獲取Stream中的第一個元素

  • Optional<T> findAny()

    隨機獲取Stream中的一個元素

  • public static<T> Builder<T> builder()

    獲取一個Stream的構造器

  • public static<T> Stream<T> empty()

    獲取一個空的Stream

  • public static<T> Stream<T> of(T t)

向一個Stream中添加元素

  • public static<T> Stream<T> of(T... values)

    向一個Stream中添加元素列表

  • public static<T> Stream<T> iterate(final T seed, final UnaryOperator<T> f)

    迭代Stream

  • public static<T> Stream<T> generate(Supplier<T> s)

    根據指定需求生成一個Stream

  • public static <T> Stream<T> concat(Stream<? extends T> a, Stream<? extends T> b)

連接兩個Stream成一個Stream

下面就通過具體實例來看每個方法的使用方式:

Person類:


filter(Predicate<? super T> predicate)

獲取一批用戶中年齡大于23的人數

System.out.println(
                Arrays.asList(
                        new Person(22,"lisi"),
                        new Person(23,"zhangsan"),
                        new Person(25,"wangwu"),
                        new Person(24,"zhouliu"),
                        new Person(27,"zhaoqi")
                        ).stream()
                        .filter(x -> x.age > 23)
                        .count()
        );

結果為:

3
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市闷煤,隨后出現的幾起案子童芹,更是在濱河造成了極大的恐慌,老刑警劉巖鲤拿,帶你破解...
    沈念sama閱讀 221,576評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件假褪,死亡現場離奇詭異,居然都是意外死亡近顷,警方通過查閱死者的電腦和手機生音,發(fā)現死者居然都...
    沈念sama閱讀 94,515評論 3 399
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來窒升,“玉大人缀遍,你說我怎么就攤上這事”バ耄” “怎么了域醇?”我有些...
    開封第一講書人閱讀 168,017評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長蓉媳。 經常有香客問我譬挚,道長,這世上最難降的妖魔是什么酪呻? 我笑而不...
    開封第一講書人閱讀 59,626評論 1 296
  • 正文 為了忘掉前任减宣,我火速辦了婚禮,結果婚禮上号杠,老公的妹妹穿的比我還像新娘蚪腋。我一直安慰自己丰歌,他們只是感情好姨蟋,可當我...
    茶點故事閱讀 68,625評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著立帖,像睡著了一般眼溶。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上晓勇,一...
    開封第一講書人閱讀 52,255評論 1 308
  • 那天堂飞,我揣著相機與錄音灌旧,去河邊找鬼。 笑死绰筛,一個胖子當著我的面吹牛枢泰,可吹牛的內容都是我干的。 我是一名探鬼主播铝噩,決...
    沈念sama閱讀 40,825評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼衡蚂,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了骏庸?” 一聲冷哼從身側響起毛甲,我...
    開封第一講書人閱讀 39,729評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎具被,沒想到半個月后玻募,有當地人在樹林里發(fā)現了一具尸體,經...
    沈念sama閱讀 46,271評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡一姿,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,363評論 3 340
  • 正文 我和宋清朗相戀三年七咧,在試婚紗的時候發(fā)現自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片叮叹。...
    茶點故事閱讀 40,498評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡坑雅,死狀恐怖,靈堂內的尸體忽然破棺而出衬横,到底是詐尸還是另有隱情裹粤,我是刑警寧澤,帶...
    沈念sama閱讀 36,183評論 5 350
  • 正文 年R本政府宣布蜂林,位于F島的核電站遥诉,受9級特大地震影響,放射性物質發(fā)生泄漏噪叙。R本人自食惡果不足惜矮锈,卻給世界環(huán)境...
    茶點故事閱讀 41,867評論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望睁蕾。 院中可真熱鬧苞笨,春花似錦、人聲如沸子眶。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,338評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽臭杰。三九已至粤咪,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間渴杆,已是汗流浹背寥枝。 一陣腳步聲響...
    開封第一講書人閱讀 33,458評論 1 272
  • 我被黑心中介騙來泰國打工宪塔, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人囊拜。 一個月前我還...
    沈念sama閱讀 48,906評論 3 376
  • 正文 我出身青樓某筐,卻偏偏與公主長得像,于是被迫代替她去往敵國和親冠跷。 傳聞我的和親對象是個殘疾皇子来吩,可洞房花燭夜當晚...
    茶點故事閱讀 45,507評論 2 359

推薦閱讀更多精彩內容

  • Spring Cloud為開發(fā)人員提供了快速構建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務發(fā)現蔽莱,斷路器弟疆,智...
    卡卡羅2017閱讀 134,699評論 18 139
  • ** 寫在前面的話:本人作為一枚純技術愛好者,一直喜歡利用閑暇寫一點自己研究的收獲和體會盗冷。雖然力求謹慎怠苔,但個人見解...
    石馬木寸閱讀 4,165評論 6 20
  • 本文將會詳細講解Stream的使用方法(不會涉及Stream的原理,因為這個系列的文章還是一個快速學習如何使用的)...
    光劍書架上的書閱讀 5,578評論 0 16
  • 原鏈接:http://www.cnblogs.com/langtianya/p/3757993.html JDK各...
    把愛放下會走更遠閱讀 1,114評論 0 10
  • 剛剛拔了智齒仪糖,你整個臉腫起來了柑司。盡管喝著他給你煮的黑米粥,卻依然一點胃口也沒有锅劝。 “我吃飽了攒驰。”你放下勺子故爵。 “阿...
    悠悠子V閱讀 333評論 0 0