当前位置: 首页 > news >正文

Java 集合操作完整清单(Java 8+ Stream API)

Java 集合操作完整清单(Java 8+ Stream API)

给你一个完整的Java集合操作清单,包含代码示例。现代Java推荐使用Stream API进行集合操作。

1. 过滤操作

// 过滤符合条件的元素

List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5, 6);

List<Integer> even = numbers.stream()

.filter(n -> n % 2 == 0)

.collect(Collectors.toList()); // [2, 4, 6]

// 去重

List<Integer> withDups = Arrays.asList(1, 2, 2, 3, 3, 3);

List<Integer> distinct = withDups.stream()

.distinct()

.collect(Collectors.toList()); // [1, 2, 3]

// 分页(跳过前n个,取前m个)

List<Integer> paged = numbers.stream()

.skip(2)

.limit(3)

.collect(Collectors.toList()); // [3, 4, 5]

2. 映射操作

// 类型转换

List<String> strings = Arrays.asList("1", "2", "3");

List<Integer> ints = strings.stream()

.map(Integer::parseInt)

.collect(Collectors.toList()); // [1, 2, 3]

// 提取对象属性

List<User> users = getUsers();

List<String> names = users.stream()

.map(User::getName)

.collect(Collectors.toList());

// 扁平化(将多个集合合并为一个)

List<List<Integer>> nested = Arrays.asList(

Arrays.asList(1, 2),

Arrays.asList(3, 4)

);

List<Integer> flat = nested.stream()

.flatMap(List::stream)

.collect(Collectors.toList()); // [1, 2, 3, 4]

3. 排序操作

List<Integer> nums = Arrays.asList(3, 1, 4, 1, 5, 9);

// 自然排序(升序)

List<Integer> sorted = nums.stream()

.sorted()

.collect(Collectors.toList()); // [1, 1, 3, 4, 5, 9]

// 自定义排序(降序)

List<Integer> reversed = nums.stream()

.sorted(Comparator.reverseOrder())

.collect(Collectors.toList()); // [9, 5, 4, 3, 1, 1]

// 按对象属性排序

List<User> users = getUsers();

List<User> sortedByAge = users.stream()

.sorted(Comparator.comparing(User::getAge))

.collect(Collectors.toList());

// 多字段排序

List<User> sortedMulti = users.stream()

.sorted(Comparator.comparing(User::getAge)

.thenComparing(User::getName))

.collect(Collectors.toList());

4. 聚合操作(取最大、最小、求和等)

List<Integer> nums = Arrays.asList(3, 1, 4, 1, 5, 9);

// 求和

int sum = nums.stream()

.mapToInt(Integer::intValue)

.sum(); // 23

// 取最大值

Optional<Integer> max = nums.stream()

.max(Integer::compareTo); // Optional[9]

// 取最小值

Optional<Integer> min = nums.stream()

.min(Integer::compareTo); // Optional[1]

// 平均值

double avg = nums.stream()

.mapToDouble(Integer::doubleValue)

.average()

.orElse(0.0); // 3.83

// 统计汇总

IntSummaryStatistics stats = nums.stream()

.mapToInt(Integer::intValue)

.summaryStatistics();

// stats.getCount(), stats.getSum(), stats.getMin(), stats.getMax(), stats.getAverage()

// 自定义reduce

Optional<Integer> product = nums.stream()

.reduce((a, b) -> a * b); // 所有数相乘

5. 集合操作(交集、并集、差集)

Set<Integer> set1 = new HashSet<>(Arrays.asList(1, 2, 3, 4));

Set<Integer> set2 = new HashSet<>(Arrays.asList(3, 4, 5, 6));

// 交集

Set<Integer> intersection = set1.stream()

.filter(set2::contains)

.collect(Collectors.toSet()); // [3, 4]

// 并集

Set<Integer> union = new HashSet<>(set1);

union.addAll(set2); // [1, 2, 3, 4, 5, 6]

// 差集(set1有但set2没有)

Set<Integer> difference = set1.stream()

.filter(n -> !set2.contains(n))

.collect(Collectors.toSet()); // [1, 2]

// 对称差集(只在其中一个集合的元素)

Set<Integer> disjunctive = set1.stream()

.filter(n -> !set2.contains(n))

.collect(Collectors.toSet());

set2.stream()

.filter(n -> !set1.contains(n))

.forEach(disjunctive::add); // [1, 2, 5, 6]

6. 分组操作

List<User> users = getUsers();

// 按单个字段分组

Map<String, List<User>> groupedByCity = users.stream()

.collect(Collectors.groupingBy(User::getCity));

// 按条件分组

Map<String, List<User>> groupedByAgeRange = users.stream()

.collect(Collectors.groupingBy(u ->

u.getAge() > 30 ? "中年" : "青年"

));

// 多级分组

Map<String, Map<String, List<User>>> multiGroup = users.stream()

.collect(Collectors.groupingBy(User::getCity,

Collectors.groupingBy(User::getGender)));

// 分组并统计数量

Map<String, Long> countByCity = users.stream()

.collect(Collectors.groupingBy(User::getCity,

Collectors.counting()));

// 分组并求和

Map<String, Integer> sumAgeByCity = users.stream()

.collect(Collectors.groupingBy(User::getCity,

Collectors.summingInt(User::getAge)));

// 分组并取最大

Map<String, Optional<User>> maxAgeByCity = users.stream()

.collect(Collectors.groupingBy(User::getCity,

Collectors.maxBy(Comparator.comparing(User::getAge))));

7. 分区操作

// 按布尔条件分区(只能分为两组)

List<Integer> nums = Arrays.asList(1, 2, 3, 4, 5, 6);

Map<Boolean, List<Integer>> partitioned = nums.stream()

.collect(Collectors.partitioningBy(n -> n % 2 == 0));

// {false=[1, 3, 5], true=[2, 4, 6]}

8. 匹配操作

List<Integer> nums = Arrays.asList(1, 2, 3, 4, 5);

// 是否全部匹配

boolean allEven = nums.stream()

.allMatch(n -> n % 2 == 0); // false

// 是否有任意匹配

boolean anyEven = nums.stream()

.anyMatch(n -> n % 2 == 0); // true

// 是否全部不匹配

boolean noneMatch = nums.stream()

.noneMatch(n -> n > 10); // true

9. 查找操作

List<Integer> nums = Arrays.asList(1, 2, 3, 4, 5);

// 查找第一个

Optional<Integer> first = nums.stream()

.findFirst(); // Optional[1]

// 查找任意一个(并行流时更高效)

Optional<Integer> any = nums.stream()

.findAny(); // Optional[1]

// 配合过滤查找第一个匹配

Optional<Integer> firstEven = nums.stream()

.filter(n -> n % 2 == 0)

.findFirst(); // Optional[2]

10. 其他实用操作

List<String> strings = Arrays.asList("a", "b", "c", "d");

// 字符串拼接

String joined = strings.stream()

.collect(Collectors.joining(", ")); // "a, b, c, d"

// 转Map

Map<Integer, String> idToNameMap = users.stream()

.collect(Collectors.toMap(User::getId, User::getName));

// 处理Map的Entry

Map<String, Integer> map = new HashMap<>();

map.entrySet().stream()

.filter(entry -> entry.getValue() > 10)

.forEach(System.out::println);

// 去重并保持顺序

List<Integer> withDups = Arrays.asList(1, 2, 2, 3, 3, 3);

List<Integer> distinctOrdered = withDups.stream()

.distinct()

.collect(Collectors.toList()); // [1, 2, 3]

// 自定义收集器(如果需要)

Collector<Integer, ?, List<Integer>> customCollector =

Collectors.toCollection(LinkedList::new);

性能提示

大数据量:考虑使用并行流 .parallelStream()

原始类型:使用 IntStream, LongStream, DoubleStream 避免装箱开销

提前过滤:先过滤减少后续操作的数据量

避免多次遍历:尽量在一次流操作中完成所有处理

传统方式 vs Stream API

// 传统for循环

List<Integer> result = new ArrayList<>();

for (Integer n : numbers) {

if (n > 3) {

result.add(n * 2);

}

}

// Stream方式(更简洁)

List<Integer> result = numbers.stream()

.filter(n -> n > 3)

.map(n -> n * 2)

.collect(Collectors.toList());

http://www.cnnetsun.cn/news/62471.html

相关文章:

  • 数控滑台的基本概念
  • FMD辉芒微电子8位微控制器芯片,荣获“深圳市制造业单项冠军企业”认定
  • Unity XR 编辑器VR设备模拟功能
  • 国产银河麒麟SP3服务器部署mysql主从同步
  • BabylonJS开发:从零基础到项目实战
  • HDF5文件学习笔记
  • Web应用安全头部信息验证方法与测试实践
  • 学校食堂出入库管理软件
  • 基于MATLAB的线性判别分析(LDA)降维算法实现方案
  • 【Java毕设源码分享】基于springboot+vue的线上高校奖助学金系统设计与实现(程序+文档+代码讲解+一条龙定制)
  • 【Java毕设源码分享】基于springboot+vue的高校教室资源管理系统的设计与实现(程序+文档+代码讲解+一条龙定制)
  • 被裁后,我却更自由了:不同求职机构的冰与火
  • 从焦虑到从容:这款AI工具如何帮我高效完成5万字硕士论文
  • minio分片上传
  • 基于MATLAB实现深度学习图像分类
  • 9、UNIX/Linux 文件操作全解析
  • 企业SRC支付漏洞EDUSRC众测挖掘思路技巧操作分享
  • webpack输出代码报错到指定文本文件
  • 自然语言处理容易混淆知识点(二)BERT和BERTopic的区别
  • GPT-5.2与Gemini 3.0 Pro技术选型指南:核心能力对比+第三方API接入全攻略
  • LangSmith:AI Agent开发者的效率神器,从OpenAI到LangChain都在用!
  • 智能图表生成:当数据分析从“怎么做图”变成“问什么”——某平台新工作流的技术解构与应用前瞻
  • 4、VXLAN BGP EVPN基础解析
  • 22、VXLAN BGP EVPN 多 Pod 与多 Fabric 部署方案解析
  • 2025年十大项目管理系统排名:综合功能、场景与用户口碑的权威榜单
  • Docker部署前端项目,收藏这篇就够了
  • Python+Vue的大学生就业信息管理系统 Pycharm django flask
  • 15 分钟获现场信号,30 分钟建指挥链路!分布式系统赋能救援 “秒响应”
  • 自动化测试中的常见陷阱与规避
  • 6-4 WPS JS宏 不重复随机取值应用