Java8---Stream
1、概述
1.1、Stream 提供了 一种 对 Java集合 运算、表达的 高阶抽象;
1.2、Stream 将 要处理的元素 看作 一种流,流在管道中传输,并且 可以 在管道的节点 进行处理(筛选、排序、聚合...);
1.3、关键概念
a,数据源:
集合、数组、I/Ochannel、产生器generator...
b,聚合操作:
filter、map、reduce、find、match、sorted...
1.4、Stream的2个基础特征:
a,Pipelining
中间操作 都会 返回流对象本身。 这样 多个操作可以串联成一个管道, 如同流式风格(fluent style)。
这样做可以对操作进行优化, 比如延迟执行(laziness)和短路( short-circuiting)。
b,内部迭代
以前对集合遍历 都是 通过Iterator或者For-Each的方式, 显式的 在集合外部进行迭代, 这叫做外部迭代。
Stream提供了内部迭代的方式, 通过访问者模式(Visitor)实现。
2、生成流方式
2.1、stream() 为集合创建 串行流;
2.2、parallelStream() 为集合创建 并行流;
public class Test { public static void main(String[] args) { List<Integer> list=new ArrayList<>(10); list.add(2); list.add(3); list.add(4); list.add(1); list.add(5); list.add(2); /** * List --- forEach() */ list.stream().forEach(a->{ System.out.print(a); }); System.out.println(); list.stream().forEach(System.out::print); System.out.println(); /** * List --- sorted() */ List<Integer> sortList=list.stream().sorted().collect(Collectors.toList()); System.out.println(sortList); List<Integer> deSortList=list.stream().sorted((o1,o2)->o2-o1).collect(Collectors.toList()); System.out.println(deSortList); /** * List --- distinct() */ List<Integer> distinctList=list.stream().distinct().collect(Collectors.toList()); System.out.println(distinctList); /** * List --- count() */ Long count=list.stream().count(); System.out.println(count+":"+list.size()); /** * List --- limit() */ List<Integer> limitList=list.stream().limit(3).collect(Collectors.toList()); System.out.println(limitList); /** * List --- filter() */ Long count1=list.stream().filter(a->a==1).count(); System.out.println(count1); } }