JAVA 使用 Stream 中 Collectors 工具类 基础操作

简介: JAVA 使用 Stream 中 Collectors 工具类 基础操作

JAVA 使用 Stream 中 Collectors 工具类 基础操作

求取最大值、最小值、求和、求平均值

image.png

class A {
    companion object {
        private val list = ArrayList<Test>()
        @RequiresApi(Build.VERSION_CODES.N)
        @JvmStatic
        fun main(args: Array<String>) {
            println("-----------------------------------")
            list.add(Test(120, "语文"))
            list.add(Test(12, "数学"))
            list.add(Test(70, "英语"))
            list.add(Test(92, "化学"))
            list.add(Test(10, "物理"))
            list.add(Test(96, "生物"))
            //求取最大值
            val maxBy = list.stream().collect(Collectors.maxBy(Comparator.comparing(Test::score)))
            //求取最小值
            val minBy = list.stream().collect(Collectors.minBy(Comparator.comparing(Test::score)))
            //平均值 averagingInt\averagingDouble、averagingInt、averagingLong
            val averagingInt = list.stream().collect(Collectors.averagingInt(Test::score))
            println("-maxBy----${maxBy}-minBy-${minBy}---averagingInt-${averagingInt}")
            //summarizingDouble、summarizingInt、summarizingLong  TODO 求得:计数、求平均、求和、最大、最小
            val summarizingInt = list.stream().collect(Collectors.summarizingInt(Test::score))
            println("-summarizingInt--总数--${summarizingInt.count} 总分--${summarizingInt.sum} 平均分--${summarizingInt.average} 最小--${summarizingInt.min} 最大--${summarizingInt.max} ")
        }
    }
    data class Test(var score: Int, val suject: String = "")
}
目录
相关文章
|
5天前
|
缓存 前端开发 Java
【前端学java】java基础巩固复习巩固语法练习-工具类的封装(14)
【8月更文挑战第10天】java基础巩固,工具类的封装
11 1
【前端学java】java基础巩固复习巩固语法练习-工具类的封装(14)
|
3天前
|
Java API 开发者
|
11天前
|
存储 算法 Oracle
19 Java8概述(Java8概述+lambda表达式+函数式接口+方法引用+Stream+新时间API)
19 Java8概述(Java8概述+lambda表达式+函数式接口+方法引用+Stream+新时间API)
38 8
|
8天前
|
自然语言处理 Java API
"告别Java8 Stream噩梦,JDFrame神器来袭!让你的代码简洁如诗,效率翻倍,编程新体验等你尝鲜!"
【8月更文挑战第11天】Java 8的Stream API以强大的函数式编程能力革新了集合数据处理方式,但其抽象概念和复杂的链式调用让不少开发者望而却步。为此,JDFrame框架应运而生,通过直观易懂的操作符简化Stream使用,减少代码量并提高效率。
25 3
|
13天前
|
数据可视化 IDE Java
Java8的Stream流太难用了?看看JDFrame带来的革新体验
【8月更文挑战第6天】在Java开发者的日常工作中,Java 8引入的Stream API无疑是一个革命性的特性,它极大地简化了集合(Collection)的处理方式,使得数据操作更加声明式、函数式。然而,对于初学者或是从早期Java版本迁移过来的开发者而言,Stream API的复杂性和抽象性可能会成为一道门槛。今天,我们就来探讨如何通过JDFrame这样的工具或框架,以及掌握一些高效学习策略,让Java Stream的使用变得更加得心应手。
48 5
|
12天前
|
存储 Java API
探索Java中的Stream API: 提升数据处理的效率与优雅
在Java的海洋中,Stream API如同一股清流,为数据处理注入了新的活力。本文将深入探讨Stream API的核心概念、操作以及它如何改变我们编写和理解代码的方式。通过实际案例,我们将揭示这一现代编程范式如何简化集合处理,提高代码的可读性与性能。
|
16天前
|
Java API 数据处理
Java 8新特性:Stream API的实用指南
【8月更文挑战第3天】在Java 8中,最引人注目的新特性之一是Stream API。这个API允许开发者以声明式方式处理数据集合,提供了一种高效且易于理解的数据处理方法。本文将介绍Stream API的基本概念、常用操作以及如何在实际开发中应用。
|
2天前
|
并行计算 Java API
|
4天前
|
前端开发 Oracle Java
Java 22 新增利器: 使用 Java Stream Gather 优雅地处理流中的状态
本文我们分析了 什么 是 “流”,对比了 Java 上几种常见的 “流”库,引入和详细介绍了 Java 22 中的 Stream Gather API 。同时也简单分享了利用 虚拟线程 如何简化 StreammapConcurrent操作符的实现。
|
4天前
|
Java API
Java8 Lambda 设计和实现问题之在Java 8的Stream API中,parallel=false时collect方法是如何实现的
Java8 Lambda 设计和实现问题之在Java 8的Stream API中,parallel=false时collect方法是如何实现的