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);
}
}
浙公网安备 33010602011771号