简介:
A sequence of elements supporting sequential and parrallel aggregate operations,Stream是一组用来处理数组、集合的API。
Java8 引入函数式编程的原因:
- 代码简洁:函数时式编程写出的代码简洁且意图明确,使用Stream接口可以告别for循环,但是性能不一定比for循环好;
- 多核友好:Java函数式编程使编写并行程序变得简单,直接调用parallel()方法即可;
Stream特性:
- 不是数组结构,没有内部存储;
- 不支持索引访问;
- 延迟计算;
- 支持并行;
- 很容易生成数组或集合(List,Set);
- 支持过滤、查找、转换、汇总和聚合等操作;
Stream运行机制:
Stream分为源source、中间操作和终止操作。Stream的源可以是一个数组、一个集合、一个生成器方法、一个I/O通道等等。一个Stream可以有零个或者多个中间操作,每一个中间操作都会返回一个新的流,供下一个操作使用。一个流只会有一个终止操作,Stream只有遇到终止操作,它的源才开始执行遍历操作。
Stream的创建:
- 通过数组
public void generateByArray(){
String[] list = {"a","b","c","d"};
Stream<String> stream = Stream.of(list);
}
- 通过集合
public void generateByList(){
List<String> list = Arrays.asList("a","b","c","d");
Stream<String> stream = list.stream();
}
- 通过Stream.generate方法创建,如果不加limit会无限输出
public void generateByGenerator(){
Stream<Integer> stream = Stream.generate(() -> 1);
stream.limit(10).forEach(System.out::println);
}
- 通过Stream.iterate方法来创建,如果不加limit会无限输出
public void generateByIterate(){
Stream<Integer> stream = Stream.iterate(1, x -> x + 1);
stream.limit(10).forEach(System.out::println);
}
- 其他API创建
public void generateByAPI(){
String string = "generateByAPI";
IntStream intStream = string.chars();
}
中间操作:
- 过滤:filter;
- 去重:distinct;
- 排序:sorted;
- 截取:limit,skip:
- 转换:map,flapMap;
- 其他:peek;
终止操作:
- 循环:forEach;
- 计算:min、max、count、average;
- 匹配:anyMatch、allMatch、noneMatch、findFirst、findAny;
- 汇聚:reduce;
- 收集器:toArray、collect;