news 2026/5/15 8:53:55

277. Java Stream API - 去重与排序:Stream 中的 distinct() 与 sorted()

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
277. Java Stream API - 去重与排序:Stream 中的 distinct() 与 sorted()

文章目录

  • 277. Java Stream API - 去重与排序:Stream 中的 `distinct()` 与 `sorted()`
      • 🎯 目标
    • 🧼 `distinct()` —— 去重利器
      • 📌 定义:
      • 🔍 `distinct()` 的内部原理
      • ✅ 示例:整数去重
      • 🔽 输出:
    • 📊 `sorted()` —— 排序操作
      • 📌 定义:
      • 🧠 工作机制:
      • ✅ 示例 1:自然排序(String 实现了 Comparable)
      • 🔽 输出:
      • ✅ 示例 2:按长度排序(使用 Comparator)
      • 🔽 输出:
    • 🔁 无限流中的表现对比
      • ✅ `distinct()` 适用于无限流
        • 示例:
      • 🔽 输出:
      • ❌ `sorted()` 不适用于无限流
        • 示例(反例):
      • ⚠️ 输出:
    • ✅ 总结对比
    • 🧠 延伸小技巧
      • 🧩 想去重自定义对象?

277. Java Stream API - 去重与排序:Stream 中的distinct()sorted()


🎯 目标

本节将讲解如何使用distinct()去除重复值,使用sorted()对流元素排序,包括:

  • 它们的工作机制
  • 使用示例
  • 注意事项(如可用于无限流与否)
  • 性能影响

🧼distinct()—— 去重利器

📌 定义:

distinct()会移除流中重复的元素,依据是元素的:

  • hashCode()
  • equals()

所以:你使用的对象必须正确实现这两个方法,才能保证去重有效。


🔍distinct()的内部原理

distinct()并不像大多数中间操作那样是“无状态”的:

  • 内部维护一个Set集合来追踪已见过的元素。
  • 每处理一个元素,会尝试把它加入Set
    • ✅ 加入成功:表示是第一次出现,传递下游。
    • ❌ 加入失败:说明是重复的,直接丢弃。

⚠️ 因为要维护状态,所以它会占用内存,但能即时输出结果。


✅ 示例:整数去重

List<Integer>ints=List.of(1,4,2,1,3,3);List<Integer>distincts=ints.stream().distinct().toList();System.out.println("distinct ints: "+distincts);

🔽 输出:

distinct ints:[1,4,2,3]

✅ 说明:重复的13被移除了,且保持原始顺序。


📊sorted()—— 排序操作

📌 定义:

sorted()用于将流中的元素排序。

它有两个重载:

Stream<T>sorted();// 自然顺序(元素必须实现 Comparable)Stream<T>sorted(Comparator<?superT>c);// 自定义顺序

🧠 工作机制:

  • sorted()是有状态的中间操作。
  • 必须读取所有元素后再排序输出
  • 所以它不适用于无限流,会导致挂起或卡死。

✅ 示例 1:自然排序(String 实现了 Comparable)

List<String>strings=List.of("one","two","three","four");List<String>naturalSort=strings.stream().sorted().toList();System.out.println("natural sort: "+naturalSort);

🔽 输出:

natural sort:[four,one,three,two]

👉 字符串按照字典序排序。


✅ 示例 2:按长度排序(使用 Comparator)

List<String>shortestFirst=strings.stream().sorted(Comparator.comparingInt(String::length)).toList();System.out.println("shortest first: "+shortestFirst);

🔽 输出:

shortest first:[one,two,four,three]

👉 按字符串长度升序排序。


🔁 无限流中的表现对比

distinct()适用于无限流

可以边处理边输出,只要有足够的终止条件(如limit()),就不会卡死。

示例:
varints=IntStream.iterate(0,i->i+1).map(i->i/3).distinct().limit(5).toArray();System.out.println("ints = "+Arrays.toString(ints));

🔽 输出:

ints=[0,1,2,3,4]

🌟 它发现新值就会推送给下游,表现非常高效!


sorted()不适用于无限流

因为它必须先收集所有元素再排序,所以当流无限时,它永远等不到结束,程序会卡死或耗尽内存。

示例(反例):
int[]ints=IntStream.iterate(0,i->i+1).map(i->i/3).sorted().limit(5).toArray();System.out.println("ints = "+Arrays.toString(ints));

⚠️ 输出:

<程序将无限等待,永远没有结果>

✅ 总结对比

方法是否有状态是否可用于无限流内部机制
distinct()有状态✅ 支持使用Set去重
sorted()有状态❌ 不支持使用缓冲区收集+排序

🧠 延伸小技巧

🧩 想去重自定义对象?

你的类必须实现正确的:

  • equals()
  • hashCode()

示例:

recordUser(Stringname,intage){}List<User>users=...;users.stream().distinct().toList();// 正常去重

如用的是Comparator排序:

users.stream().sorted(Comparator.comparing(User::age)).toList();
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 7:15:47

YOLOV8模型如何训练无人机航拍视角建筑垃圾检测数据集 建立基于深度学习框架YOLOV8 无人机垃圾识别检测系统

无人机航拍视角建筑垃圾检测数据集无人机多场景下建筑材料与垃圾等目标的无人机视角检测数据集 &#x1f4ca; 多场景无人机视角目标检测数据集概览表项目内容数据集名称多场景建筑材料与垃圾无人机检测数据集应用场景城市管理、工地巡检、环境监测、智慧城市等采集视角无人机航…

作者头像 李华
网站建设 2026/5/1 6:47:20

语音合成质量评估实战:从主观测试到自动化评分完整指南

语音合成质量评估实战&#xff1a;从主观测试到自动化评分完整指南 【免费下载链接】F5-TTS Official code for "F5-TTS: A Fairytaler that Fakes Fluent and Faithful Speech with Flow Matching" 项目地址: https://gitcode.com/gh_mirrors/f5/F5-TTS 语音…

作者头像 李华
网站建设 2026/5/8 21:26:05

Code Llama 70B 代码生成实战:从零到企业级部署全解析

Code Llama 70B 代码生成实战&#xff1a;从零到企业级部署全解析 【免费下载链接】CodeLlama-70b-hf 项目地址: https://ai.gitcode.com/hf_mirrors/ai-gitcode/CodeLlama-70b-hf 在当今快速发展的AI编程时代&#xff0c;Code Llama 70B作为Meta最新发布的700亿参数代…

作者头像 李华
网站建设 2026/5/1 7:15:53

spider-flow动态表达式引擎深度解析:架构设计与执行机制

spider-flow动态表达式引擎深度解析&#xff1a;架构设计与执行机制 【免费下载链接】spider-flow 新一代爬虫平台&#xff0c;以图形化方式定义爬虫流程&#xff0c;不写代码即可完成爬虫。 项目地址: https://gitcode.com/gh_mirrors/sp/spider-flow 在当今数据驱动的…

作者头像 李华
网站建设 2026/5/10 18:21:01

电影购票|基于springboot 电影购票系统(源码+数据库+文档)

电影购票 目录 基于springboot vue电影购票系统 一、前言 二、系统功能演示 三、技术选型 四、其他项目参考 五、代码参考 六、测试参考 七、最新计算机毕设选题推荐 八、源码获取&#xff1a; 基于springboot vue电影购票系统 一、前言 博主介绍&#xff1a;✌️大…

作者头像 李华
网站建设 2026/5/14 10:07:16

物业管理|基于springboot 物业管理系统(源码+数据库+文档)

物业管理 目录 基于springboot vue物业管理系统 一、前言 二、系统功能演示 三、技术选型 四、其他项目参考 五、代码参考 六、测试参考 七、最新计算机毕设选题推荐 八、源码获取&#xff1a; 基于springboot vue物业管理系统 一、前言 博主介绍&#xff1a;✌️大…

作者头像 李华