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,并同时执行一个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进行规约操作

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

    对Stream进行规约操作
    
  • <U> U reduce(U identity,
    BiFunction<U, ? super T, U> accumulator,
    BinaryOperator<U> combiner)

对Stream进行规约操作

  • <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
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,637评论 18 139
  • ** 写在前面的话:本人作为一枚纯技术爱好者,一直喜欢利用闲暇写一点自己研究的收获和体会。虽然力求谨慎,但个人见解...
    石马木寸阅读 4,156评论 6 20
  • 本文将会详细讲解Stream的使用方法(不会涉及Stream的原理,因为这个系列的文章还是一个快速学习如何使用的)...
    光剑书架上的书阅读 5,553评论 0 16
  • 原链接:http://www.cnblogs.com/langtianya/p/3757993.html JDK各...
    把爱放下会走更远阅读 1,111评论 0 10
  • 刚刚拔了智齿,你整个脸肿起来了。尽管喝着他给你煮的黑米粥,却依然一点胃口也没有。 “我吃饱了。”你放下勺子。 “阿...
    悠悠子V阅读 331评论 0 0