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);  
    }  
}
相关推荐
Monkey-旭32 分钟前
Android Handler 完全指南
android·java·handler
秃狼33 分钟前
Execel文档批量替换标签实现方案
java
Brookty44 分钟前
Java线程安全与中断机制详解
java·开发语言·后端·学习·java-ee
pingzhuyan1 小时前
python入门篇12-虚拟环境conda的安装与使用
python·ai·llm·ocr·conda
香蕉可乐荷包蛋1 小时前
排序算法 (Sorting Algorithms)-Python示例
python·算法·排序算法
Sylvia-girl1 小时前
排序查找算法,Map集合,集合的嵌套,Collections工具类
java·算法·排序算法
TT哇1 小时前
【分治】归并排序——排序数组(medium)
java·算法·排序算法
飞速移动的代码菌1 小时前
【DataWhale】快乐学习大模型 | 202507,Task08笔记
笔记·学习
给力学长1 小时前
自习室预约小程序的设计与实现
java·数据库·vue.js·elementui·小程序·uni-app·node.js
不在了情绪1 小时前
[ The Missing Semester of Your CS Education ] 学习笔记 Vim篇
笔记·学习·vim