Java集合的核心价值是简化业务逻辑、减少if判断与bug:用HashSet高效去重与校验;用Map替代硬编码状态映射,提升可维护性;用List+Comparator链式多条件排序;配合Optional避免空指针,聚焦业务本质。

Java集合不是用来炫技的,而是帮你在业务代码里少写if、少绕弯、少出bug。用对了,原本十几行遍历+判断的逻辑,可能一行stream就搞定。
用Set快速去重和权限校验
用户提交的订单商品ID列表,后端要检查有没有重复、有没有非法ID。传统写法常是两层for循环或Map计数,容易漏边界。换成HashSet就清爽得多:
- 把合法商品ID预加载进Set
(比如从缓存读一次) - 用户传来的ID列表转成new HashSet(inputIds),size变小说明有重复
- 再用validIds.containsAll(inputIds)一步校验全量合法性
比逐个contains快,语义也更直白——“我只关心它在不在集合里”,不是“我得遍历找一遍”。
用Map替代硬编码的状态映射
订单状态码(1=待支付,2=已发货,3=已完成)散落在if-else或switch里,改一个就要翻好几个类。抽成Map
立即学习“Java免费学习笔记(深入)”;
- 状态名统一从Map取:statusMap.get(order.getStatus()),前端展示不拼错
- 状态变更逻辑封装成函数式接口:actionMap.get(newStatus).accept(order),新增状态只需put新动作,不碰老代码
- 配合Enum做key,还能编译期防错
用List+Comparator优雅处理多条件排序
后台订单列表要按“未读>已读、金额降序、创建时间升序”排,不用手写Comparator实现类。直接链式调用:
orders.sort(comparing(Order::isRead)
.thenComparing(Order::getAmount, reverseOrder())
.thenComparing(Order::getCreateTime));
逻辑平铺可读,改顺序只动一行,加条件也只多一个thenComparing。比嵌套三目运算或自定义compare方法干净太多。
用Optional+Collection避免空指针和冗余判空
查用户收货地址,可能为空;取默认地址又可能为空。以前满屏if (list != null && !list.isEmpty())。现在可以:
- addresses.stream().filter(Address::isDefault).findFirst().orElse(defaultAddr)
- 或者封装工具方法:safeGetFirst(list, defaultVal),内部用Optional.ofNullable处理null安全
集合本身不解决null,但配合Stream和Optional,能把防御性代码压缩到最低,聚焦真实业务意图。
基本上就这些——集合不是语法糖,是把“我要做什么”翻译成“数据怎么组织、怎么流转”的桥梁。用熟了,代码会自己变短、变稳、变容易改。









