Java Collections工具类

Collections 类:Java 中提供的一组静态方法,用于操作集合。常用方法:

1. 排序
  • Collections.sort(List<T> list)
    • 对指定列表进行升序排序。
  • Arrays.asList 将一个数组转化为一个List集合
java 复制代码
List<Integer> numbers = Arrays.asList(5, 2, 8, 1);
Collections.sort(numbers);
2. 查找
  • Collections.binarySearch(List<? extends Comparable<? super T>> list, T key)

    • 在已排序的列表中查找指定元素,返回其索引。
    java 复制代码
    int index = Collections.binarySearch(numbers, 2);  // 返回 1
3. 反转和洗牌
  • Collections.reverse(List<?> list)

    • 反转列表中的元素顺序。
    java 复制代码
    Collections.reverse(numbers);
  • Collections.shuffle(List<?> list)

    • 随机打乱列表中的元素顺序。
    java 复制代码
    Collections.shuffle(numbers);
4. 最大值和最小值
  • Collections.max(Collection<? extends T> coll)

    • 返回集合中的最大元素。
    java 复制代码
    int max = Collections.max(numbers);
  • Collections.min(Collection<? extends T> coll)

    • 返回集合中的最小元素。
    java 复制代码
    int min = Collections.min(numbers);
5. 频率
  • Collections.frequency(Collection<?> c, Object o)

    • 计算指定元素在集合中出现的次数。
    java 复制代码
    int freq = Collections.frequency(numbers, 2);
6. 替换
  • Collections.replaceAll(List<T> list, T oldVal, T newVal)

    • 替换列表中所有的旧值为新值。
    java 复制代码
    Collections.replaceAll(numbers, 2, 20);
7. 创建不可变集合
  • Collections.unmodifiableList(List<? extends T> list)

    • 返回指定列表的不可变视图。
    java 复制代码
    List<Integer> immutableList = Collections.unmodifiableList(numbers);
8. 单例集合
  • Collections.singleton(T o)

    • 返回一个包含单个指定元素的不可变集合。
    java 复制代码
    Set<Integer> singletonSet = Collections.singleton(1);
9. 空集合
  • Collections.emptyList()

    • 返回一个空的不可变列表。
    java 复制代码
    List<String> emptyList = Collections.emptyList();
10. 同步集合
  • Collections.synchronizedList(List<T> list)

    • 返回线程安全的列表。
    java 复制代码
    List<Integer> synchronizedList = Collections.synchronizedList(new ArrayList<>());
示例:
java 复制代码
package ServletProjects;  
  
import java.util.*;  
  
public class Main {  
    public static void main(String[] args) {  
        List<Integer> numbers = new ArrayList<>(Arrays.asList(5, 2, 8, 1, 2));  
  
        Collections.sort(numbers);  
        System.out.println("排序后" + numbers);  
  
        Collections.shuffle(numbers);  
        System.out.println("打乱后 " + numbers);  
  
        int max = Collections.max(numbers);  
        int min = Collections.min(numbers);  
        System.out.println("最大值 " + max + ",最小值: " + min);  
  
        int freq = Collections.frequency(numbers, 2);  
        System.out.println("2的次序为: " + freq);  
  
        Collections.replaceAll(numbers, 2, 20);  
        System.out.println("替换后: " + numbers);  
    }  
}
相关推荐
听麟4 小时前
HarmonyOS 6.0+ 跨端智慧政务服务平台开发实战:多端协同办理与电子证照管理落地
笔记·华为·wpf·音视频·harmonyos·政务
yuuki2332334 小时前
【C++】继承
开发语言·c++·windows
222you4 小时前
Redis的主从复制和哨兵机制
java·开发语言
铉铉这波能秀4 小时前
LeetCode Hot100数据结构背景知识之集合(Set)Python2026新版
数据结构·python·算法·leetcode·哈希算法
江湖有缘4 小时前
零基础入门:使用 Docker 快速部署 Organizr 个人主页
java·服务器·docker
牛奔4 小时前
如何理解 Go 的调度模型,以及 G / M / P 各自的职责
开发语言·后端·golang
梵刹古音5 小时前
【C++】 析构函数
开发语言·c++
chilavert3185 小时前
技术演进中的开发沉思-357:重排序(下)
java·后端
Boop_wu5 小时前
Spring生态
java·后端·spring
jzheng86105 小时前
Spring Boot(快速上手)
java·spring boot·后端