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

JAVA中的Collections 类

文章目录

  • 前言
  • 一、 排序方法 sort() 和 reverseOrder()
    • 1. sort(List<T> list)
    • 2.sort(List<T> list, Comparator<? super T> c)
  • 二、查找方法 max(), min()
    • 1.max(Collection<? extends T> coll)
    • 2.min(Collection<? extends T> coll)
    • 3.max(Collection<? extends T> coll, Comparator<? super T> comp)
  • 三、 填充方法 fill(), copy()
    • 1.fill(List<? super T> list, T obj)
    • 2.copy(List<? super T> dest, List<? extends T> src)
  • 四、反转方法 reverse()
  • 总结


前言

Collections 是 Java 中的一个工具类,位于 java.util 包中,提供了一些静态方法来操作和返回集合框架中的集合对象。它主要用于操作集合对象,如列表、集合和映射等,提供了排序、查找、反转、填充、交换等常见操作。
在这里插入图片描述
Collections和Collection不同,前者是集合的操作类,后者是集合接口

Collections类定义了一系列用于操作集合的静态方法


一、 排序方法 sort() 和 reverseOrder()

注意
实现一个类的对象之间比较大小,该类要实现Comparable接口

并且重写compareTo()方法

1. sort(List list)

将列表中的元素按自然顺序进行排序。适用于元素实现了 Comparable 接口的集合。

List<Integer> list = Arrays.asList(5, 3, 8, 1);
Collections.sort(list);  // 输出:[1, 3, 5, 8]

2.sort(List list, Comparator<? super T> c)

根据提供的比较器 Comparator 对列表进行排序。

List<String> list = Arrays.asList("apple", "banana", "cherry");
Collections.sort(list, (s1, s2) -> s2.compareTo(s1));  // 按逆字典顺序排序

二、查找方法 max(), min()

1.max(Collection<? extends T> coll)

返回集合中的最大元素,要求元素实现 Comparable 接口。

List<Integer> list = Arrays.asList(1, 2, 3, 4);
Integer max = Collections.max(list);  // 输出:4

2.min(Collection<? extends T> coll)

返回集合中的最小元素,要求元素实现 Comparable 接口。

List<Integer> list = Arrays.asList(1, 2, 3, 4);
Integer min = Collections.min(list);  // 输出:1

3.max(Collection<? extends T> coll, Comparator<? super T> comp)

使用自定义的比较器返回最大元素。

List<String> list = Arrays.asList("apple", "banana", "cherry");
String max = Collections.max(list, (s1, s2) -> s1.length() - s2.length());  // 按字符串长度比较

三、 填充方法 fill(), copy()

1.fill(List<? super T> list, T obj)

将列表中的每个元素设置为给定的对象 obj。

List<String> list = new ArrayList<>(Arrays.asList("a", "b", "c"));
Collections.fill(list, "filled");
System.out.println(list);  // 输出:[filled, filled, filled]

2.copy(List<? super T> dest, List<? extends T> src)

将 src 列表的元素复制到 dest 列表。dest 列表必须至少有和 src 列表一样多的元素空间。


List<String> src = Arrays.asList("a", "b", "c");
List<String> dest = new ArrayList<>(Arrays.asList("x", "y", "z"));
Collections.copy(dest, src);
System.out.println(dest);  // 输出:[a, b, c]

四、反转方法 reverse()

反转列表的元素顺序。

List<Integer> list = Arrays.asList(1, 2, 3, 4);
Collections.reverse(list);
System.out.println(list);  // 输出:[4, 3, 2, 1]

总结

Collections 是 Java 集合框架中非常实用的工具类,它封装了对集合的常见操作,如排序、查找、填充、复制、反转等,使开发者无需重复造轮子,提高了代码的可读性和开发效率。熟练掌握 Collections 的常用方法,是 Java 开发中提升集合处理能力的重要一步。

http://www.lryc.cn/news/593568.html

相关文章:

  • 【数据结构】二叉树初阶详解(一):树与二叉树基础 + 堆结构全解析
  • windows wsl2-05-docker 安装笔记
  • 光盘存储器的组成与分类
  • 从“数字土著”到“数据公民”:K-12数据伦理课程的设计、实施与成效追踪研究
  • Codeforces Round 1037 (Div. 3)(补题)
  • Codeforces Round 1037(Div.3)
  • 搭建比分网服务器怎么选数据不会卡顿?
  • 配置华为交换机接口链路聚合-支持服务器多网卡Bind
  • 数据结构:字符串(Strings)
  • RGB转灰度方法汇总
  • 本地安装部署Unstructured-api
  • Flutter基础(前端教程①③-单例)
  • 优先算法——专题十:哈希表
  • kafka--基础知识点--6--AR、ISR、OSR
  • Django母婴商城项目实践(九)- 商品列表页模块
  • [论文阅读] 软件工程 | 用模糊逻辑“解锁”项目成功:告别非黑即白的评估时代
  • 多进程服务器
  • 千线万网,电路之行——LVS检查的内核逻辑
  • k8s 基本架构
  • K8s与Helm实战:从入门到精通
  • 第五章 用Java实现JVM之运行时数据区
  • Linux内核设计与实现 - 第5章 系统调用
  • 堆堆堆,咕咕咕
  • Java行为型模式---中介者模式
  • 【办公类-107-02】20250719视频MP4转gif(削减MB)
  • Triton的核心概念与简单入门
  • 突破研究边界!探索OpenAI o3与o4-mini模型的无限可能
  • Attu-Milvus向量数据库可视化工具
  • 《Linux系统配置实战:NTP时间同步与SSH免密登录全流程指南》​​
  • Linux练习二