码迷,mamicode.com
首页 > 编程语言 > 详细

Java8新特性 --Stream

时间:2017-11-26 18:44:55      阅读:153      评论:0      收藏:0      [点我收藏+]

标签:sort   integer   定义排序   集合类   lambda   int   source   一个   lam   

一、 创建Stream

  1. 创建Stream方式一: 集合类的stream()或 parallelStream()

    java List<String> list = new ArrayList<>(); Stream<String> stream = list.stream();

  2. 创建Stream方式二: 通过Arrays中的静态方法stream()获取

    String[] strings = new String[10];
    Stream<String> stream1 = Arrays.stream(strings);
  3. 创建Stream方式三: 通过Stream 类中的静态方法of()

    Stream<String> stream2 = Stream.of("aa", "bb", "cc");
  4. 创建Stream方式四: 无限流
    迭代:

    Stream<Integer> stream3 = Stream.iterate(0, (x) -> x + 2);

    生成:

    Stream.generate(() -> Math.random());

二、中间操作

  • 筛选和切片  
      filter 接受Lambda, 从stream中筛选出满足条件的元素。
      limit 限定stram中元素的数量。满足了limit数量以后,stream中以后的迭代终止,类似与短路操作。
      skip(n) 跳过元素,返回一个扔掉了前n个元素的stream。若stream中元素不足n个,则返回一个空stream。与limit(n)互补
      distinct 通过stream中元素的hashCode() 和 equels() 去除重复元素

  • 映射
      map 接受Lambda, 将元素转换成其他形式或提取信息。接受一个函数作为参数,该函数会被应用到每个元素上,并将其映射成一个新的元素。
      flatMap 接受一个函数作为参数,将stream中的每个值都换成另一个stream,然后把所有的stream连成一个stream。

  • 排序
      sorted() 自然排序 按照Comparable排序
      sorted(Comparator com) 自定义排序 按照comparator排序

  • 归约
      T reduce(T identity, BinaryOperator

  • 收集
     Optional
  1. 内部迭代: 迭代操作由Stream API完成
  2. 外部迭代: 自己写Iteriator

三、 并行流与串行流

并行流 就是把一个内容分成多个数据块,并用不同的线程分别处理每个数据块的流。Java 8 中将并行进行了优化,我们可以很容易的对数据进行并行操作。Stream API 可以声明性地通过 parallel() 与sequential() 在并行流与顺序流之间进行切换。

Java8新特性 --Stream

标签:sort   integer   定义排序   集合类   lambda   int   source   一个   lam   

原文地址:http://www.cnblogs.com/zheting/p/7899556.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!