Java Stream API

简介:

  A sequence of elements supporting sequential and parrallel aggregate operations,Stream是一组用来处理数组、集合的API。

Java8 引入函数式编程的原因:
  1. 代码简洁:函数时式编程写出的代码简洁且意图明确,使用Stream接口可以告别for循环,但是性能不一定比for循环好;
  2. 多核友好:Java函数式编程使编写并行程序变得简单,直接调用parallel()方法即可;
Stream特性:
  1. 不是数组结构,没有内部存储;
  2. 不支持索引访问;
  3. 延迟计算;
  4. 支持并行;
  5. 很容易生成数组或集合(List,Set);
  6. 支持过滤、查找、转换、汇总和聚合等操作;
Stream运行机制:

  Stream分为源source、中间操作和终止操作。Stream的源可以是一个数组、一个集合、一个生成器方法、一个I/O通道等等。一个Stream可以有零个或者多个中间操作,每一个中间操作都会返回一个新的流,供下一个操作使用。一个流只会有一个终止操作,Stream只有遇到终止操作,它的源才开始执行遍历操作。

Stream的创建:
  1. 通过数组
public void generateByArray(){
    String[] list = {"a","b","c","d"};
    Stream<String> stream = Stream.of(list);
}
  1. 通过集合
public void generateByList(){
    List<String> list = Arrays.asList("a","b","c","d");
    Stream<String> stream = list.stream();
}
  1. 通过Stream.generate方法创建,如果不加limit会无限输出
public void generateByGenerator(){
    Stream<Integer> stream = Stream.generate(() -> 1);
    stream.limit(10).forEach(System.out::println);
}
  1. 通过Stream.iterate方法来创建,如果不加limit会无限输出
public void generateByIterate(){
    Stream<Integer> stream = Stream.iterate(1, x -> x + 1);
    stream.limit(10).forEach(System.out::println);
}
  1. 其他API创建
public void generateByAPI(){
    String string = "generateByAPI";
    IntStream intStream = string.chars();
}
中间操作:
  1. 过滤:filter;
  2. 去重:distinct;
  3. 排序:sorted;
  4. 截取:limit,skip:
  5. 转换:map,flapMap;
  6. 其他:peek;
终止操作:
  1. 循环:forEach;
  2. 计算:min、max、count、average;
  3. 匹配:anyMatch、allMatch、noneMatch、findFirst、findAny;
  4. 汇聚:reduce;
  5. 收集器:toArray、collect;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值