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);  
    }  
}
相关推荐
冷雨夜中漫步6 分钟前
python反转列表reverse()和[::-1]哪个效率更高
开发语言·python
rainbow68899 分钟前
Python面向对象编程与异常处理实战
开发语言·python
weixin1997010801612 分钟前
锦程物流item_get - 获取详情接口对接全攻略:从入门到精通
数据库·python
それども12 分钟前
什么是MalformedStreamException,和WebKitFormBoundary有什么关系
java
三伏52212 分钟前
Cortex-M3权威指南Cn第十章——笔记
笔记·单片机·嵌入式硬件·cortex-m3
AI视觉网奇26 分钟前
metahuman 购买安装记录
笔记·学习·ue5
koo36428 分钟前
pytorch深度学习笔记19
pytorch·笔记·深度学习
你撅嘴真丑31 分钟前
第八章 - 贪心法
开发语言·c++·算法
2501_9071368232 分钟前
基于Python+QT6的移动硬盘弹出工具
python·软件需求
思想在飞肢体在追38 分钟前
Springboot项目配置Nacos
java·spring boot·后端·nacos