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