`
kanpiaoxue
  • 浏览: 1782112 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

Stream类的collect方法

    博客分类:
  • java
 
阅读更多

Stream类的collect方法

参考: https://www.jianshu.com/p/ccbb42ad9551

 

  • Collectors.toSet():转换成set集合。
  • Collectors.toCollection(TreeSet::new):转换成特定的set集合。
    TreeSet<Integer> collect2 = Stream.of(1, 3, 4).collect(Collectors.toCollection(TreeSet::new));
  • Collectors.toMap(x -> x, x -> x + 1):转换成map。
    Map<Integer, Integer> collect1 = Stream.of(1, 3, 4).collect(Collectors.toMap(x -> x, x -> x + 1));
  • Collectors.minBy(Integer::compare):求最小值,相对应的当然也有maxBy方法。
  • Collectors.averagingInt(x->x):求平均值,同时也有averagingDouble、averagingLong方法。
    System.out.println(Stream.of(1, 2, 3).collect(Collectors.averagingInt(x->x)));
  • Collectors.summingInt(x -> x)):求和。
  • Collectors.summarizingDouble(x -> x):可以获取最大值、最小值、平均值、总和值、总数。
    DoubleSummaryStatistics summaryStatistics = Stream.of(1, 3, 4).collect(Collectors.summarizingDouble(x -> x));
    summaryStatistics.getAverage();//平均值
  • Collectors.groupingBy(x -> x)有三种方法,查看源码可以知道前两个方法最终调用第三个方法,第二个参数默认HashMap::new 第三个参数默认Collectors.toList(),参考SQL的groupBy。
    Map<Integer, List<Integer>> map = Stream.of(1, 3, 3, 4).collect(Collectors.groupingBy(x -> x));
    Map<Integer, Long> map = Stream.of(1, 3, 3, 4).collect(Collectors.groupingBy(x -> x, Collectors.counting()));
    HashMap<Integer, Long> hashMap = Stream.of(1, 3, 3, 4).collect(Collectors.groupingBy(x -> x, HashMap::new, Collectors.counting()));
  • Collectors.partitioningBy(x -> x > 2),把数据分成两部分,key为ture/false。第一个方法也是调用第二个方法,第二个参数默认为Collectors.toList()。
    Map<Boolean, List<Integer>> collect5 = Stream.of(1, 3, 4).collect(Collectors.partitioningBy(x -> x > 2));
    Map<Boolean, Long> collect4 = Stream.of(1, 3, 4).collect(Collectors.partitioningBy(x -> x > 2, Collectors.counting()));
  • Collectors.joining(","):拼接字符串。
    System.out.println(Stream.of("a", "b", "c").collect(Collectors.joining(",")));
  • Collectors.reducing(0, x -> x + 1, (x, y) -> x + y)):在求累计值的时候,还可以对参数值进行改变,这里是都+1后再求和。跟reduce方法有点类似,但reduce方法没有第二个参数。
    System.out.println(Stream.of(1, 3, 4).collect(Collectors.reducing(0, x -> x + 1, (x, y) -> x + y)));
  • Collectors.collectingAndThen(Collectors.joining(","), x -> x + "d"):先执行collect操作后再执行第二个参数的表达式。这里是先拼接字符串,再在最后+ "d"。
    String str= Stream.of("a", "b", "c").collect(Collectors.collectingAndThen(Collectors.joining(","), x -> x + "d"));
  • Collectors.mapping(...):跟map操作类似,只是参数有点区别。
    System.out.println(Stream.of("a", "b", "c").collect(Collectors.mapping(x -> x.toUpperCase(), Collectors.joining(","))));
作者:抹茶菌
链接:https://www.jianshu.com/p/ccbb42ad9551
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
 
===================
    public static void test003() throws Exception {
        TreeSet<Integer> collect2 = Stream.of(1, 3, 4, 2).collect(Collectors.toCollection(TreeSet::new));
        System.out.println(collect2);// [1, 2, 3, 4]

        List<KeyValue<Integer, String>> kvs = Lists.newArrayList();
        for (int i = 0; i < 3; i++) {
            kvs.add(new KeyValue<>(i, "hello-" + i));
        }
        Map<Integer, String> map = kvs.stream().collect(Collectors.toMap(KeyValue::getKey, kv -> {
            return kv.getValue() + "&&" + kv.getKey();
        }));
        System.out.println(map);// {0=hello-0&&0, 1=hello-1&&1, 2=hello-2&&2}

        String joinResult = Stream.of("a", "b", "c")
                .collect(Collectors.mapping(x -> x.toUpperCase(), Collectors.joining(",")));
        System.out.println(joinResult);// A,B,C

        Map<Integer, Integer> collect1 = Stream.of(1, 3, 4).collect(Collectors.toMap(x -> x, x -> x + 1));
        System.out.println(collect1);// {1=2, 3=4, 4=5}

        // Collectors.joining(","):拼接字符串。
        System.out.println(Stream.of("a", "b", "c").collect(Collectors.joining(",")));// a,b,c

        System.out.println(Stream.of("a", "b", "c")
                .collect(Collectors.collectingAndThen(Collectors.joining(","), x -> x + "d")));// a,b,cd

    }
  
分享到:
评论

相关推荐

    讲透JAVAStream的collect用法与原理远比你想象的更强大

    在提供的代码片段中,`collect`方法与`Collectors.toList()`结合使用,将Stream中的元素收集到一个List中。这是一个简单的收集操作,适用于大多数基本需求: ```java List&lt;Employee&gt; employees = stream.filter...

    详解Java8 Collect收集Stream的方法

    Java8 Collect收集Stream的方法详解 Java8 中的 Collect 收集 Stream 的方法是 Java8 中一个重要的功能,主要用于对 Stream 中的元素进行收集和处理。下面是对该方法的详细介绍。 title: 详解 Java8 Collect收集...

    【转】Stream类

    标题中的“【转】Stream类”表明我们将讨论Java编程语言中的Stream API,这是一个在Java 8及更高版本中引入的强大工具,用于处理集合数据。Stream API提供了声明式编程风格,使得对集合的操作更加高效和简洁。 ...

    day13【Stream流、方法引用】笔记.pdf

    - **引用类上的实例方法**:例如 `ContainingType::methodName` - **引用构造器**:例如 `ClassName::new` #### 构造器引用 在Stream流操作中,我们可以使用构造器引用作为方法引用的一种特殊情况。例如,如果我们...

    Java Stream的基本概念以及创建方法

    对于实现了Collection接口的类(如List、Set、Queue等),可以调用`stream()`或`parallelStream()`方法创建Stream。例如: ```java List&lt;Integer&gt; list = new ArrayList(Arrays.asList(1, 2, 3, 4, 5)); Stream...

    node-stream-collect:收集流的输出

    使用collect()方法创建直通流并collect事件。 const { Collect } = require ( 'stream-collect' ) ; const file = fs . createReadableStream ( 'myfile' ) ; // Collect using a promise file . pipe ( new ...

    JAVA8 STREAM COLLECT GROUPBY分组实例解析

    JAVA8 STREAM COLLECT GROUPBY分组实例解析提供了一个强大的工具来实现数据分组和统计,通过使用Collectors.groupBy()方法和Collectors.mapping()方法,我们可以轻松地实现数据分组和统计,并且输出结果也非常直观...

    Stream流常用方法

    - **collect方法**:将Stream转换回集合或其他形式的数据结构。 这些方法可以组合使用,形成所谓的“链式操作”,使代码更加简洁且易于理解。Stream API的出现使得Java的编程风格更加接近函数式编程,提高了代码的...

    java8-Stream API终端操作.pdf

    collect 方法是 Java Stream API 中最常用的终端操作,它可以将 Stream 处理结果转换为集合类。collect 方法可以将元素收集到 Set、List、Map 等集合类中。collect 方法的使用可以分为两步:第一步是对 Stream 处理...

    Java Stream使用(学习资料)

    使用集合类的 stream() 方法,可以将集合类对象转换为管道流。例如: List&lt;String&gt; list = Arrays.asList("Monkey", "Lion", "Giraffe", "Lemur"); Stream&lt;String&gt; streamFromList = list.stream(); 六、将文本...

    Stream_Java8.pdf

    2. **统计员工的最高薪资、平均薪资、薪资总数**:使用`collect`配合`Collectors`工具类完成统计。 ```java DoubleSummaryStatistics stats = employees.stream() .collect(Collectors.summarizingDouble...

    java使用stream对日期排序

    - `collect()`: 将Stream转换为其他数据结构,如List或Set。 - `Comparator`: 排序的依据,用于定义比较规则。 3. 使用Stream API对日期排序: 假设我们有一个`LocalDate`对象的列表`List&lt;LocalDate&gt; dates`,...

    Java的集合框架和StreamAPI

    创建流的方法包括 Stream.of()、Stream.generate()、Stream.iterate() 等,转换流的方法包括 filter、map、sorted 等,收集结果的方法包括 toArray、collect 等。 Stream API 的一个重要特点是支持并行流,通过 ...

    Java-Stream流详解.pptx.pptx

    - **使用Arrays.stream()**:针对数组,可以使用Arrays类的`stream()`方法,如`Arrays.stream(int[])`,创建特定类型的流。 - **Stream的静态方法**:如`Stream.of()`, `Stream.ofNullable()`, `Stream.empty()`等,...

    全网详解(波哥)Java8新特性(Lambda、Stream、LocalDate等)新特性

    全网详解(波哥)Java8新特性(Lambda、Stream、LocalDate等)新特性 自学java的同行们应该都要学习java8的新特性,譬如:(Lambda、Stream、LocalDate等)!本人在学习java的时候看的是波哥的视频,确实讲的不错,很...

    jiangdx-stream-master.zip

    1. **Stream的创建**:Stream可以通过集合类的`stream()`或`parallelStream()`方法创建,也可以通过`Arrays.stream()`、`Files.lines()`等静态工厂方法创建。 2. **中间操作**:Stream上的大部分操作都是中间操作,...

    Java8 Stream学习

    不同于传统的集合类(如List、Set等),Stream API支持更加灵活的数据处理方式,使得开发人员能够以声明式的方式来处理数据。 **Stream** 是一种对数据源进行各种高效聚合操作的机制,它强调的是数据的流动性和处理...

    stream流操作demo

    - 通过集合的`stream()`或`parallelStream()`方法创建。 - 使用`Arrays.stream()`或`IntStream.range()`等方法处理数组。 - I/O流也可以转换为Stream,如`Files.lines()`。 3. **中间操作(Intermediate ...

    day13【Stream流】.md

    本章节重点介绍了 Java 8 中 Stream 流的基本概念、特点以及与集合类之间的差异,并深入探讨了函数式接口(特别是 `Predicate&lt;T&gt;`)的使用方法。通过具体示例,我们还学习了如何获取 Stream 流、执行常见操作以及...

Global site tag (gtag.js) - Google Analytics