代码改变世界

java stream

2022-03-06 18:03  tonyniu8  阅读(275)  评论(0编辑  收藏  举报

简介

Stream 是 Java8 中处理集合的关键抽象概念,它可以指定你希望对集合进行的操作,可以执行非常复杂的查找、过滤和映射数据等操作。使用Stream API 对集合数据进行操作,就类似于使用 SQL 执行的数据库查询。也可以使用 Stream API 来并行执行操作。简而言之,Stream API 提供了一种高效且易于使用的处理数据的方式。
#特点
1 . 不是数据结构,不会保存数据。
2. 不会修改原来的数据源,它会将操作后的数据保存到另外一个对象中。(保留意见:毕竟peek方法可以修改流中元素)
3. 惰性求值,流在中间处理过程中,只是对操作进行了记录,并不会立即执行,需要等到执行终止操作的时候才会进行实际的计算。

无状态:指元素的处理不受之前元素的影响;

有状态:指该操作只有拿到所有元素之后才能继续下去。

非短路操作:指必须处理所有元素才能得到最终结果;

短路操作:指遇到某些符合条件的元素就可以得到最终结果,如 A || B,只要A为true,则无需判断B的结果。

三、具体用法

流的常用创建方法

1.1 使用Collection下的 stream() 和 parallelStream() 方法

     // create stream
        Integer[] abc = {1, 2, 3, 4, 5, 6, 6, 7};
        List<Integer> l2 = Arrays.asList(abc);
        Stream<Integer> stream = l2.stream();

1.2使用Arrays 中的 stream() 方法,将数组转成流
1.3 使用Stream中的静态方法:of()、iterate()、generate()
1.4 使用 BufferedReader.lines() 方法,将每行内容转成流
1.5 使用 Pattern.splitAsStream() 方法,将字符串分隔成流

流的中间操作

2.1 筛选与切片
filter:过滤流中的某些元素
limit(n):获取n个元素
skip(n):跳过n元素,配合limit(n)可实现分页
distinct:通过流中元素的 hashCode() 和 equals() 去除重复元素

        // slice,and filter
        Stream<Integer> resultStream = stream.filter(s -> s > 2).distinct().skip(2).limit(2);
        resultStream.forEach(System.out::print);

  • mapping
    map:接收一个函数作为参数,该函数会被应用到每个元素上,并将其映射成一个新的元素。
        //map
        Person junjun = new Person("junjun", 18);
        Person tony = new Person("tony", 21);
        Person zhizhi = new Person("zhizhi", 1);
        List<Person> persons = new ArrayList<>();
        persons.add(junjun);
        persons.add(tony);
        persons.add(zhizhi);
        Stream s1 = persons.stream().map(p -> p.getName());
        s1.forEach(System.out::println);
  • sort
    sorted():自然排序,流中元素需实现Comparable接口
    sorted(Comparator com):定制排序,自定义Comparator排序器
        //sorted
        System.out.println("sorted");
        persons.stream().sorted((p1, p2) -> {
            return Integer.compare(p1.age, p2.age);
        }).forEach(p -> System.out.print(p.name + ","));

流的中指操作

3.1 匹配,聚合操作
allMatch:接收一个 Predicate 函数,当流中每个元素都符合该断言时才返回true,否则返回false
noneMatch:接收一个 Predicate 函数,当流中每个元素都不符合该断言时才返回true,否则返回false
anyMatch:接收一个 Predicate 函数,只要流中有一个元素满足该断言则返回true,否则返回false
findFirst:返回流中第一个元素
findAny:返回流中的任意元素
count:返回流中元素的总个数
max:返回流中元素最大值
min:返回流中元素最小值

        // 匹配,聚合操作
        boolean anymatch = stream.anyMatch(e -> e > 5);