Java集合与泛型:从基础到高级应用
Java 集合与泛型从基础到高级应用2025–2026 生产视角Java 集合框架Collection Framework 泛型Generics是 Java 5 以来最核心的语言级基础设施。到 2025–2026 年集合框架本身语法和 API 变化不大Java 21 引入的 SequencedCollection 是近年最大一次结构性调整但使用方式、性能认知、类型系统玩法已经发生了显著演进尤其在虚拟线程、记录类records、模式匹配、流式处理深度融合的背景下。一、2025–2026 视角下的核心对比表最实用分类维度基础用法Java 5–17现代高级用法Java 21 推荐为什么值得升级泛型擦除认知只知道“编译后消失”理解 erasure bridge method signature attribute反射、代理、序列化场景必须懂通配符使用? extends / ? super 写得很乱PECS 原则严格遵守 尽量用接口而非实现类作为类型参数边界减少编译错误 提高 API 灵活性集合创建方式new ArrayList()List.of() / Set.of() / Map.of() / Collections.emptyXXX()不可变 简洁 内存友好尤其是小集合顺序保证依赖具体实现ArrayList 有序、HashSet 无序优先用 SequencedCollection / SequencedSet / SequencedMap统一 first/last/reversed() 接口不可变集合Collections.unmodifiableXXXList.of() / Set.copyOf() / Collectors.toUnmodifiableList()更安全、更高效内部优化流 集合转换stream().collect(toList())toList() / toSet() / toUnmodifiableList() / toCollection()Java 16 更简洁记录类 集合—record 作为元素 / 作为 key需重写 hashCode/equalsDDD 值对象首选模式匹配 集合if (obj instanceof List)switch record patterns deconstruction简化类型判断 解构提取二、SequencedCollection 家族Java 21 最大集合变革Java 21 引入了三个新接口现在已经是标配SequencedCollection← Collection 的子接口提供getFirst()、getLast()、addFirst()、addLast()、reversed()SequencedSet← Set SequencedCollectionLinkedHashSet、TreeSet 实现了它SequencedMapK,V← MapLinkedHashMap 实现了它真实意义终于有统一的方式访问“有明确顺序的集合”的首尾元素而不用关心底层是 List / Deque / LinkedHashSet / LinkedHashMap。// 现代写法推荐voidprocess(SequencedCollectionStringitems){Stringfirstitems.getFirst();Stringlastitems.getLast();SequencedCollectionStringreverseditems.reversed();// 视图反转不复制}三、高级泛型技巧面试 生产常考PECS 原则Producer Extends, Consumer Super只读Producer →? extends T只写Consumer →? super T// 经典例子voidcopy(List?extendsNumbersrc,List?superNumberdest){for(Numbern:src)dest.add(n);}泛型 记录类recordsJava 16recordPoint(intx,inty){}ListPointpointsList.of(newPoint(1,2),newPoint(3,4));// 模式匹配解构Java 21 增强if(points.getFirst()instanceofPoint(intx,inty)){System.out.println(xx, yy);}捕获转换Capture Conversion与? 通配符的局限// 经典陷阱voidswap(List?list,inti,intj){// 编译不通过// list.set(i, list.get(j)); // ? 无法赋值}解决用泛型方法 辅助方法privatestaticTvoidswapInternal(ListTlist,inti,intj){Ttemplist.get(i);list.set(i,list.get(j));list.set(j,temp);}voidswap(List?list,inti,intj){swapInternal(list,i,j);// 捕获转换发生在这里}泛型 函数式接口高阶用法// 典型工具方法publicstaticT,RListRtransform(List?extendsTlist,Function?superT,?extendsRmapper){returnlist.stream().map(mapper).toList();}四、2025–2026 生产中最推荐的集合创建 / 操作模式// 推荐小集合不可变ListStringrolesList.of(admin,user,guest);// 动态构建可变 → 不可变ListStringmutablenewArrayList();// ... add manyListStringimmutableList.copyOf(mutable);// 流收集Java 16SetUseractiveUsersusers.stream().filter(User::isActive).collect(Collectors.toUnmodifiableSet());// 排序 去重 保持插入顺序LinkedHashSetStringuniqueOrdereditems.stream().distinct().sorted().collect(Collectors.toCollection(LinkedHashSet::new));五、常见性能 / 陷阱对照表生产必知场景推荐实现为什么不选其他常见踩坑点频繁随机读ArrayListget(i) O(1)大量 add(0) / remove(0) 导致整体搬移需要保持插入顺序 去重LinkedHashSetO(1) contains 插入顺序容量规划不当导致 rehash 频繁需要自然排序 / 范围查询TreeSet / TreeMaplog(n) 操作 排序元素未实现 Comparable 或 Comparator小集合10List.of() / Set.of()内存极省 不可变误用 new ArrayList(List.of(…)) 多一层作为 Map 的 keyrecord / 自定义 immutable 类天然 immutable 可 hashCode/equals可变对象做 key → 灾难高并发读写非虚拟线程CopyOnWriteArrayList/Set写慢读快写频繁导致 GC 压力六、2025–2026 面试 / 设计高频深度问题SequencedCollection 出现前为什么 LinkedHashSet 没有 getFirst()List.of() 内部到底用了什么数据结构为什么比 Arrays.asList() 更好泛型擦除后ArrayList 和 ArrayList 在运行时是否是同一个类为什么不能 new T()类型擦除导致? extends Object 和 ? 有什么区别什么时候用哪个record 作为 HashMap 的 key 需要注意什么虚拟线程时代CopyOnWriteArrayList 是否还有存在的必要如何写一个类型安全的泛型 Builder你当前项目里集合 泛型用得最重的是哪一块是 DTO 转换、缓存设计、配置管理、流式处理、还是自定义泛型工具类或者哪部分还想再深挖泛型擦除字节码细节、PECS 更多实战、SequencedXXX 源码、模式匹配 集合解构等
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2431018.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!