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);  
    }  
}
相关推荐
zzzsde19 分钟前
【c++】深入理解string类(3):典型OJ题
开发语言·c++
雨落在了我的手上23 分钟前
C语言趣味小游戏----猜数字小游戏
c语言·开发语言·游戏
大飞pkz24 分钟前
【设计模式】迭代器模式
开发语言·设计模式·c#·迭代器模式
聪明的笨猪猪28 分钟前
Java SE “JDK1.8新特性”面试清单(含超通俗生活案例与深度理解)
java·经验分享·笔记·面试
MoRanzhi120329 分钟前
2. Pandas 核心数据结构:Series 与 DataFrame
大数据·数据结构·人工智能·python·数据挖掘·数据分析·pandas
Excuse_lighttime32 分钟前
除自身以外数组的乘积
java·数据结构·算法·leetcode·eclipse·动态规划
Vahala0623-孔勇33 分钟前
Redisson分布式锁源码深度解析:RedLock算法、看门狗机制,以及虚拟线程下的锁重入陷阱与解决
java·开发语言·分布式
Coision.38 分钟前
Linux C: 函数
java·c语言·算法
经典199241 分钟前
Elasticsearch 讲解及 Java 应用实战:从入门到落地
java·大数据·elasticsearch
青瓦梦滋43 分钟前
【数据结构】哈希——位图与布隆过滤器
开发语言·数据结构·c++·哈希算法