Stream 作为 java8 的新特性,基于 lambda 表达式,是对集合对象功能的增强,它专注于对集合对象进行各种高效、便利的聚合操作或者大批量的数据操作,提高了编程效率和代码可读性。
Stream 的原理:将要处理的元素看做一种流,流在管道中传输,并且可以在管道的节点上处理,包括过滤筛选、去重、排序、聚合等。元素流在管道中经过中间操作的处理,最后由最终操作得到前面处理的结果。
List<String> skills = Arrays.asList("java", "golang", "c++", "c", "python", "java");
skills.stream().distinct().forEach(skill-> System.out.println(skill + ","));
System.out.println("------------");
skills.stream().distinct().forEach(System.out::println);
System.out.println("------------");
skills.stream().distinct().filter(skill -> ! skill.equals("python")).forEach(System.out::println);
/**
* map
*/
List<Integer> numList = Arrays.asList(1, 2, 3, 4, 5, 5);
numList.stream().map(num -> num * num).forEach( num -> System.out.println(num + ","));
Set<Integer> collect = numList.stream().map(num -> num * num).collect(Collectors.toSet());
collect.forEach(integer -> System.out.println(integer + ","));