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

Java 11中的Collections类详解

一、核心作用与定义

Collections类是Java集合框架的核心工具类,位于java.util包中,提供了一系列静态方法用于操作List、Set、Map等集合。其核心作用包括:

  • 简化集合操作:如排序、搜索、反转、填充等。
  • 线程安全支持:通过同步包装器(如synchronizedList)实现线程安全。
  • 不可变集合创建:提供方法生成不可修改的集合视图。
  • 算法复用:封装常见集合操作算法,避免重复实现。

在这里插入图片描述

二、常用方法详解

1. 排序相关

  • sort(List<T> list)
    按自然顺序升序排序列表,要求元素实现Comparable接口。

    List<Integer> numbers = Arrays.asList(4, 2, 5, 1, 3);
    Collections.sort(numbers); // 输出 [1, 2, 3, 4, 5]
    
  • sort(List<T> list, Comparator<? super T> c)
    按指定比较器排序,支持自定义排序逻辑。

    Comparator<Integer> descComparator = (a, b) -> b - a;
    Collections.sort(numbers, descComparator); // 降序排序
    

2. 反转与随机打乱

  • reverse(List<?> list)
    反转列表元素顺序。

    List<String> fruits = Arrays.asList("apple", "banana", "cherry");
    Collections.reverse(fruits); // 输出 [cherry, banana, apple]
    
  • shuffle(List<?> list)
    随机打乱列表元素(默认使用随机源)。

    Collections.shuffle(fruits); // 输出顺序随机,如 [banana, apple, cherry]
    

3. 搜索与替换

  • binarySearch(List<?> list, T key)
    二分搜索,要求列表已排序。

    Collections.sort(numbers);
    int index = Collections.binarySearch(numbers, 4); // 返回索引3
    
  • replaceAll(List<T> list, T oldVal, T newVal)
    替换所有旧值为新值。

    List<String> words = Arrays.asList("hello", "world", "java");
    Collections.replaceAll(words, "java", "javafx"); // 输出 [hello, world, javafx]
    

4. 极值查找

  • min(Collection<? extends T> coll)
    返回集合最小元素。

    List<Integer> numbers = Arrays.asList(3, 1, 4, 1, 5, 9);
    int min = Collections.min(numbers); // 输出1
    
  • max(Collection<? extends T> coll)
    返回集合最大元素。

    int max = Collections.max(numbers); // 输出9
    

5. 集合修改

  • fill(List<? super T> list, T obj)
    用指定元素填充列表。

    List<String> list = new ArrayList<>(Arrays.asList("a", "b", "c"));
    Collections.fill(list, "x"); // 输出 [x, x, x]
    
  • copy(List<? super T> dest, List<? extends T> src)
    复制源列表到目标列表(目标需足够长)。

    List<String> src = Arrays.asList("sun", "moon", "star");
    List<String> dest = new ArrayList<>(Arrays.asList("", "", ""));
    Collections.copy(dest, src); // 输出 [sun, moon, star]
    

6. 不可变集合

  • unmodifiableList(List<? extends T> list)
    返回不可修改的列表视图,修改会抛出UnsupportedOperationException
    List<String> original = new ArrayList<>(Arrays.asList("one", "two"));
    List<String> unmodifiable = Collections.unmodifiableList(original);
    // unmodifiable.add("three"); // 抛出异常
    

7. 其他实用方法

  • frequency(Collection<?> c, Object o)
    统计元素出现次数。

    List<String> items = Arrays.asList("apple", "banana", "apple");
    int count = Collections.frequency(items, "apple"); // 输出2
    
  • rotate(List<?>, int distance)
    循环移动元素(正数右移,负数左移)。

    List<Integer> list = Arrays.asList(1, 2, 3, 4, 5);
    Collections.rotate(list, 2); // 输出 [4, 5, 1, 2, 3]
    

三、Java 11新增特性

1. 集合工厂方法

  • List.of()Set.of()Map.of()
    快速创建不可变集合,支持1-10个元素的显式声明。

    List<String> list = List.of("Alice", "Bob", "Charlie"); // Java 11新增
    Set<Integer> set = Set.of(1, 2, 3);
    Map<String, Integer> map = Map.of("Alice", 25, "Bob", 30);
    
  • copyOf()
    复制集合为不可变形式,适用于已有集合。

    List<String> original = new ArrayList<>(Arrays.asList("a", "b"));
    List<String> copied = List.copyOf(original); // 返回不可变列表
    

2. 方法增强

  • indexOfSubList(List<?>, List<?>)
    查找子列表首次出现的位置。
    List<Integer> list = Arrays.asList(1, 2, 3, 4, 5);
    List<Integer> subList = Arrays.asList(3, 4);
    int index = Collections.indexOfSubList(list, subList); // 返回2
    

四、与Java 8的差异

1. 默认垃圾收集器变更

  • Java 11:默认使用G1 GC,优化低延迟场景,支持并发压缩和动态堆调整。
  • Java 8:默认使用Parallel GC,强调高吞吐量。

2. 集合API扩展

  • Java 11新增集合工厂方法(如List.of()),简化不可变集合创建。
  • Java 8需通过Collections.unmodifiableList手动包装。

3. 语言特性影响

  • Java 11支持局部变量类型推断(var),但Collections方法参数仍需显式类型。
    var list = List.of("a", "b"); // 有效
    Collections.sort(var list); // 无效,需显式类型
    

五、最佳实践建议

  1. 线程安全
    使用同步包装器保护非线程安全集合:

    List<String> syncList = Collections.synchronizedList(new ArrayList<>());
    
  2. 不可变集合
    优先使用List.of()Collections.unmodifiableList避免意外修改,提升代码安全性。

  3. 性能优化

    • 对大列表使用G1 GC,调整堆参数(如-XX:G1HeapRegionSize)。
    • 避免在频繁修改的集合上使用不可变视图。
  4. 算法选择
    根据场景选择合适方法:

    • 自然顺序排序用sort(List),自定义排序用sort(List, Comparator)
    • 查找极值时,优先使用min()/max()而非遍历。

六、总结

Java 11的Collections类在保持核心功能稳定的同时,通过新增工厂方法和增强现有方法,提升了开发效率和代码简洁性。用户应结合具体场景选择合适方法,并注意版本差异对代码的影响,尤其是垃圾收集器和集合API的变化。

http://www.dtcms.com/a/339479.html

相关文章:

  • Web安全攻防基础
  • 什么是IP隔离?一文讲清跨境电商/海外社媒的IP隔离逻辑
  • JVM对象创建和内存分配
  • 2025年12大AI测试自动化工具
  • 基礎複分析習題6.級數與乘積展開
  • 广东省省考备考(第八十一天8.19)——资料分析、数量(强化训练)
  • MVC、MVP、MVCC 和 MVI 架构的介绍及区别对比
  • 面试题储备-MQ篇 2-说说你对RocketMQ的理解
  • 基于WebSocket和SpringBoot聊天项目ChatterBox测试报告
  • 怎样平衡NLP技术发展中数据质量和隐私保护的关系?
  • 中科米堆CASAIM自动化三维测量设备测量汽车壳体直径尺寸
  • 多模态大模型应用落地:从图文生成到音视频交互的技术选型与实践
  • 5.1Pina介绍
  • 进程间的通信(管道,信号)
  • 知行社:以爱之名,共筑公益梦想
  • Podman:Mysql(使用卷)
  • 【Goland】:面向对象编程
  • Day 29 类的装饰器
  • 如何将任意文件一键转为PDF?
  • 【PHP】模拟斗地主后端编写
  • Matplotlib数据可视化实战:Matplotlib图表美化与进阶教程
  • 软件系统运维常见问题
  • idea中如何设置文件的编码格式
  • Python Day31 JavaScript 基础核心知识点详解 及 例题分析
  • 【完整源码+数据集+部署教程】太阳能板表面损伤检测图像分割系统源码和数据集:改进yolo11-DynamicHGNetV2
  • 服务器Linux防火墙怎样实现访问控制
  • Nginx前后端分离反代(VUE+FastAPI)
  • (一)八股(数据库/MQ/缓存)
  • 深入理解抽象类
  • C#三大核心特性