news 2026/4/18 2:01:03

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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());

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

文件加密软件哪个速度快?2025 年 6 款高效低延迟工具对比

数字化时代&#xff0c;核心文件泄露风险剧增&#xff0c;加密软件成为数据安全的关键屏障。而加密速度与延迟表现&#xff0c;直接影响办公效率与协作体验。2025 年&#xff0c;高效低延迟成为加密工具的核心竞争力。本文精选 6 款口碑工具&#xff0c;从速度、功能等维度对比…

作者头像 李华
网站建设 2026/4/16 12:04:40

亲测!这些口碑好的机油专业又好用

亲测&#xff01;这些口碑好的机油专业又好用引言机油对于汽车发动机的重要性不言而喻&#xff0c;它就像发动机的“血液”&#xff0c;起到润滑、冷却、清洁等关键作用。在市场上众多的机油品牌和型号中&#xff0c;如何选择一款适合自己车辆的优质机油呢&#xff1f;今天&…

作者头像 李华
网站建设 2026/4/17 6:37:20

上海婚介:钱多不等于脱单——我的自我觉醒之路

我出生在上海的一个中产家庭&#xff0c;父母在外企工作&#xff0c;家里有一套市中心的两居室。小时候&#xff0c;我常常幻想&#xff0c;等自己长大后&#xff0c;肯定能拥有更多财富&#xff0c;拥有更好的生活。于是&#xff0c;我一路努力读书&#xff0c;考上了上海交通…

作者头像 李华
网站建设 2026/4/18 1:53:56

HDF5完整文件结构与操作指南

HDF5完整文件结构与操作指南 目录 完整文件结构概览基础数据集类型组结构操作属性系统高级数据类型引用和链接压缩和分块可扩展数据集维度标签完整示例代码 1. 完整文件结构概览 1.1 理想的HDF5文件结构 comprehensive_example.h5 # 根文件 │ ├── &…

作者头像 李华
网站建设 2026/4/12 1:35:23

【Java毕设源码分享】基于springboot+vue的高校社团管理系统设计与实现(程序+文档+代码讲解+一条龙定制)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华