Java 教程
- Java - 首页
- Java - 概述
- Java - 历史
- Java - 特性
- Java 与 C++
- JVM - Java 虚拟机
- Java - JDK 与 JRE 与 JVM
- Java - Hello World 程序
- Java - 环境设置
- Java - 基本语法
- Java - 变量类型
- Java - 数据类型
- Java - 类型转换
- Java - Unicode 系统
- Java - 基本运算符
- Java - 注释
- Java - 用户输入
- Java - 日期和时间
Java 控制语句
- Java - 循环控制
- Java - 决策制定
- Java - if-else
- Java - switch
- Java - for 循环
- Java - for-each 循环
- Java - while 循环
- Java - do-while 循环
- Java - break
- Java - continue
面向对象编程
- Java - OOPs 概念
- Java - 对象和类
- Java - 类属性
- Java - 类方法
- Java - 方法
- Java - 变量作用域
- Java - 构造函数
- Java - 访问修饰符
- Java - 继承
- Java - 聚合
- Java - 多态
- Java - 重写
- Java - 方法重载
- Java - 动态绑定
- Java - 静态绑定
- Java - 实例初始化块
- Java - 抽象
- Java - 封装
- Java - 接口
- Java - 包
- Java - 内部类
- Java - 静态类
- Java - 匿名类
- Java - 单例类
- Java - 包装类
- Java - 枚举
- Java - 枚举构造函数
- Java - 枚举字符串
Java 内置类
Java 文件处理
Java 错误和异常
- Java - 异常
- Java - try-catch 块
- Java - try-with-resources
- Java - 多重 catch 块
- Java - 嵌套 try 块
- Java - finally 块
- Java - throw 异常
- Java - 异常传播
- Java - 内置异常
- Java - 自定义异常
Java 多线程
- Java - 多线程
- Java - 线程生命周期
- Java - 创建线程
- Java - 启动线程
- Java - 线程连接
- Java - 线程命名
- Java - 线程调度器
- Java - 线程池
- Java - 主线程
- Java - 线程优先级
- Java - 守护线程
- Java - 线程组
- Java - 关闭钩子
Java 同步
Java 网络编程
- Java - 网络编程
- Java - Socket 编程
- Java - URL 处理
- Java - URL 类
- Java - URLConnection 类
- Java - HttpURLConnection 类
- Java - Socket 类
- Java - 泛型
Java 集合
Java 接口
Java 数据结构
Java 集合算法
高级 Java
- Java - 命令行参数
- Java - Lambda 表达式
- Java - 发送电子邮件
- Java - Applet 基础
- Java - Javadoc 注释
- Java - 自动装箱和拆箱
- Java - 文件不匹配方法
- Java - REPL (JShell)
- Java - 多版本 Jar 文件
- Java - 私有接口方法
- Java - 内部类菱形运算符
- Java - 多分辨率图像 API
- Java - 集合工厂方法
- Java - 模块系统
- Java - Nashorn JavaScript
- Java - Optional 类
- Java - 方法引用
- Java - 函数式接口
- Java - 默认方法
- Java - Base64 编码解码
- Java - switch 表达式
- Java - Teeing 收集器
- Java - 微基准测试
- Java - 文本块
- Java - 动态 CDS 归档
- Java - Z 垃圾收集器 (ZGC)
- Java - 空指针异常
- Java - 打包工具
- Java - 密封类
- Java - 记录类
- Java - 隐藏类
- Java - 模式匹配
- Java - 精简数字格式化
- Java - 垃圾收集
- Java - JIT 编译器
Java 其他
- Java - 递归
- Java - 正则表达式
- Java - 序列化
- Java - 字符串
- Java - Process API 改进
- Java - Stream API 改进
- Java - 增强型 @Deprecated 注解
- Java - CompletableFuture API 改进
- Java - 流
- Java - 日期时间 API
- Java 8 - 新特性
- Java 9 - 新特性
- Java 10 - 新特性
- Java 11 - 新特性
- Java 12 - 新特性
- Java 13 - 新特性
- Java 14 - 新特性
- Java 15 - 新特性
- Java 16 - 新特性
Java APIs 和框架
Java 类引用
- Java - Scanner
- Java - 数组
- Java - 字符串
- Java - Date
- Java - ArrayList
- Java - Vector
- Java - Stack
- Java - PriorityQueue
- Java - LinkedList
- Java - ArrayDeque
- Java - HashMap
- Java - LinkedHashMap
- Java - WeakHashMap
- Java - EnumMap
- Java - TreeMap
- Java - IdentityHashMap
- Java - HashSet
- Java - EnumSet
- Java - LinkedHashSet
- Java - TreeSet
- Java - BitSet
- Java - Dictionary
- Java - Hashtable
- Java - Properties
- Java - Collection
- Java - Array
Java 有用资源
Java - Teeing 收集器
Java Collectors.teeing() 方法
Java 12 引入了一种新的静态方法到 Collectors 接口,它可以对 集合 执行两个不同的操作,然后合并结果。
语法
以下是 teeing 方法的语法:
public static Collector<T, ?, R> teeing( Collector<? super T, ?, R1> downstream1, Collector<? super T, ?, R2> downstream2, BiFunction<? super R1, ? super R2, R> merger )
此处,传递给 teeing 收集器的集合的每个元素都由 downstream1 和 downstream2 收集器处理,一旦两个收集器都完成了处理,结果就会传递给 BiFunction 收集器以合并结果或进行相应的处理。这类似于对集合调用两个函数,然后调用第三个函数来处理前两个函数的结果。
在这里,我们对集合执行不同的函数,然后使用 merger BiFunction 合并结果。
示例 - 使用 teeing 收集器获取 n 个数字的平均值
在这个例子中,我们在 downstream1 收集器中获取数字的总和,在 downstream2 收集器中获取数字的计数,然后在合并函数中计算平均值。当我们获得 流 的数字并且流的大小不可用时,这很有用。
package com.tutorialspoint; import java.util.stream.Collectors; import java.util.stream.Stream; public class Tester { public static void main(String[] args) { double mean = Stream.of(1, 2, 3, 4, 5, 6, 7) .collect(Collectors.teeing( Collectors.summingDouble(i -> i), Collectors.counting(), (sum, n) -> sum / n)); System.out.println(mean); } }
输出
让我们编译并运行上面的程序,这将产生以下结果:
4.0
示例 - 使用 teeing 收集器获取学生对象的最低分和最高分
在这个例子中,我们在 downstream1 收集器中获取学生的最低分,在 downstream2 收集器中获取学生的最高分。然后使用合并函数,我们创建一个包含具有最低分和最高分的学生的条目的哈希映射。
package com.tutorialspoint; import java.util.Arrays; import java.util.Comparator; import java.util.HashMap; import java.util.List; import java.util.stream.Collectors; public class Tester { public static void main(String args[]) { // list of students List<Student> students = Arrays.asList( new Student(1, "Robert", 390), new Student(2, "Julie", 410), new Student(3, "John", 440), new Student(4, "Michael", 420)); // collect the result in hashmap HashMap<String, Student> result = students.stream().collect( // apply the teeing operator Collectors.teeing( // get the student having highest marks Collectors.maxBy(Comparator.comparing(Student::getMarks)), // get the student having lowest marks Collectors.minBy(Comparator.comparing(Student::getMarks)), // put both student entries in the map using merger (s1, s2) -> { HashMap<String, Student> map = new HashMap<>(); map.put("Highest", s1.get()); map.put("Lowest", s2.get()); return map; } )); System.out.println(result); } } class Student { int rollNo; String name; int marks; public Student(int rollNo, String name, int marks) { this.rollNo = rollNo; this.name = name; this.marks = marks; } @Override public String toString() { return "Student [RollNo=" + rollNo + ", Name=" + name + ", Marks=" + marks + "]"; } public int getRollNo() { return rollNo; } public void setRollNo(int rollNo) { this.rollNo = rollNo; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getMarks() { return marks; } public void setMarks(int marks) { this.marks = marks; } }
输出
让我们编译并运行上面的程序,这将产生以下结果:
{Lowest=Student [RollNo=1, Name=Robert, Marks=390], Highest=Student [RollNo=3, Name=John, Marks=440]}
广告