Java_基础—Collections工具类的概述和常见方法

本文详细介绍了Java中Collections工具类的功能及使用方法,包括排序、二分查找、获取最大值、反转列表和随机置换等常用操作。
package com.saor.collections;

import java.util.ArrayList;
import java.util.Collections;

public class Demo1_Collections {
    /*
    * 如果一个类中所有的方法都是静态的,那么该类的构造方法一定被私有化了,因为防止其他类创建该类的子类对象
    * 直接通过类名.方法名()调用即可
    * * A:Collections类概述
    * 针对集合操作 的工具类
    * B:Collections成员方法
    *   常见方法
        public static <T> void sort(List<T> list)
        public static <T> int binarySearch(List<?> list,T key)
        public static <T> T max(Collection<?> coll)
        public static void reverse(List<?> list)
        public static void shuffle(List<?> list)
     */
    public static void main(String[] args) {
        //sort();
        //binarySearch();
        ArrayList<String> list = new ArrayList<>();
        list.add("a");
        list.add("c");
        list.add("d");
        list.add("f");
        list.add("g");
        //System.out.println(Collections.max(list));    //g 根据默认排序结果获取集合中的最大值
        //Collections.reverse(list);    //[g, f, d, c, a]  反转集合
        Collections.shuffle(list);      //[f, c, d, a, g]  随机置换,可以用来洗牌
        System.out.println(list);
    }

    private static void binarySearch() {
        ArrayList<String> list = new ArrayList<>();
        list.add("a");
        list.add("c");
        list.add("d");
        list.add("f");
        list.add("g");

        System.out.println(Collections.binarySearch(list, "c"));    //1
        System.out.println(Collections.binarySearch(list, "b"));    //-2    -(插入点)-1
    }

    private static void sort() {
        ArrayList<String> list = new ArrayList<>();
        list.add("c");
        list.add("a");
        list.add("b");
        list.add("d");
        list.add("a");

        System.out.println(list);   //[c, a, b, d, a]
        Collections.sort(list);
        System.out.println(list);   //[a, a, b, c, d]
    }

}
### Java `Collections` 工具类概述 `java.util.Collections` 是 Java 标准库中的一个重要工具类,封装了大量的静态方法来操作集合对象[^1]。该工具类能够处理多种集合类型,如 List、Set 等,并提供了高效的集合操作方式。 #### 主要功能介绍 #### 排序 对于实现了 `List` 接口的集合,可以通过调用 `sort()` 方法来进行排序。此方法支持自然排序(即按照元素自身的比较逻辑)定制化排序(通过传入自定义 Comparator)。下面展示了一个简单的例子: ```java import java.util.*; public class SortExample { public static void main(String[] args) { List<Integer> numbers = Arrays.asList(7, 2, 9, 4); // 自然排序 Collections.sort(numbers); System.out.println("Sorted list (natural order): " + numbers); // 定制排序 Collections.sort(numbers, new Comparator<Integer>() { @Override public int compare(Integer o1, Integer o2) { return -(o1.compareTo(o2)); // 反向排序 } }); System.out.println("Reverse sorted list: " + numbers); } } ``` #### 查找最大/最小值 为了方便开发者快速获取集合内的极值项,`Collections` 提供了 `max()` `min()` 方法。这两个函数接受一个 Collection 参数并返回相应的极大或极小值。 ```java // 获取最大值 Integer maxValue = Collections.max(listOfNumbers); System.out.println("Max value is: " + maxValue); // 获取最小值 Integer minValue = Collections.min(listOfIntegers); System.out.println("Min value is: " + minValue); ``` #### 批量添加与替换 当需要一次性向现有集合中增加多个新成员时,可利用 `addAll(Collection<? super T> c, T... elements)` 来完成这一任务;而对于想要更新整个集合内特定位置上的数据,则有专门设计好的 `replaceAll(List<T>, oldVal, newVal)` 函数可供选用。 ```java ArrayList<String> stringList = new ArrayList<>(Arrays.asList("a", "b")); boolean success = Collections.addAll(stringList, "c", "d"); if(success){ System.out.println("Added all successfully."); } stringList.replaceAll(s -> s.toUpperCase()); System.out.println("After replacing with uppercase letters: "+stringList); ``` #### 集合间复制 如果希望把源集合里的全部条目转移到目标容器里去的话,那么就可以考虑采用 `copy(Dest dest, Src src)` 这样的形式来做深拷贝工作。 ```java List<String> source = Arrays.asList("one", "two", "three"); List<String> destination = new ArrayList<>(source.size()); Collections.copy(destination, source); System.out.println("Copied content from source to destination: " + destination); ``` #### 单一实例及不可变集合创建 有时应用程序可能只需要固定不变的数据结构作为参数传递给其他组件,在这种情况下便能借助于 `singleton()`, `emptyList/Set/Map()`, 或者 `unmodifiable*()` 类的方法构建只读视图。 ```java // 创建单一实例集合 Set<String> singletonSet = Collections.singleton("only one element"); // 构建空集合 List<Object> emptyList = Collections.emptyList(); Set<?> emptySet = Collections.emptySet(); // 转换成不可修改版本 List<String> readOnlyList = Collections.unmodifiableList(new LinkedList<>()); ``` #### 同步控制 考虑到多线程环境下并发访问共享资源的安全隐患问题,`Collections` 特意准备了几种同步化的包装器模式——比如 `synchronizedCollection()`, `synchronizedList()`, `synchronizedSet()`, `synchronizedMap()` ——使得原本不具备此类特性的基础类型也能被安全地应用于高竞争度场景之中。 ```java List<String> threadSafeList = Collections.synchronizedList(new ArrayList<>()); ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值