java.util的Collections类-你可能还不知道的用法

举报
一颗苹果 发表于 2024/10/31 16:31:49 2024/10/31
【摘要】  Collections 类位于 java.util 包下,提供了许多有用的对象和方法,来简化java中集合的创建、处理和多线程管理。掌握此类将非常有助于提升开发效率和维护代码的简洁性,同时对于程序的稳定性和安全性有大有帮助。Empty集合用来创建一个空的集合EmptySetEmptyListEmptyMapSingleton集合单例集合用来创建仅包含一个对象的集合,集合不可修改,元素可为n...

 

Collections 类位于 java.util 包下,提供了许多有用的对象和方法,来简化java中集合的创建、处理和多线程管理。掌握此类将非常有助于提升开发效率和维护代码的简洁性,同时对于程序的稳定性和安全性有大有帮助。

Empty集合

用来创建一个空的集合

  1. EmptySet
  2. EmptyList
  3. EmptyMap

Singleton集合

单例集合用来创建仅包含一个对象的集合,集合不可修改,元素可为null,多线程安全( 这并不意味着对列表中元素的引用是线程安全的。如果列表中存储的是可变对象,并且多个线程可能会修改这些对象,那么你仍然需要在访问这些对象时采取适当的同步措施。

  • SingletonSet
  • SingletonList
  • SingletonMap : key ,value 均可为null



示例代码:

List<String> list = Collections.singletonList(null);

System.out.println(list.get(0));

Map<String, String> map = Collections.singletonMap("dd", null);

System.out.println( map.get("dd"));

Set<Object> set = Collections.singleton(null);

System.out.println(set);


UnmodifiableCollection 集合

用于包装集合,生成一个不可修改的集合,新集合不允许添加、删除或修改元素。 常用于返回集合的副本,以避免外部代码意外修改原始集合,增强代码的安全性和稳定性。需要注意的是仅副本不可修改,源集合任然可以修改,而且修改的内容会反馈到副本集合中。

public static void main(String[] args) {


    // 创建一个可修改的集合
    List<String> modifiableList = new ArrayList<>();
    modifiableList.add("Apple");
    modifiableList.add("Banana");
    modifiableList.add("Cherry");


    // 创建一个不可修改的集合
    Collection<String> unmodifiableList = Collections.unmodifiableCollection(modifiableList);


    // 输出不可修改的集合
    System.out.println("Unmodifiable Collection: " + unmodifiableList);


    // 尝试修改集合
    try {
        unmodifiableList.add("Date"); // 将抛出 UnsupportedOperationException
    } catch (UnsupportedOperationException e) {
        System.out.println("Cannot modify unmodifiable collection: " + e.getMessage());
    }


    // 修改原始集合
    modifiableList.add("Date");
    System.out.println("Modified Original Collection: " + modifiableList);
    System.out.println("Unmodifiable Collection after original modification: " + unmodifiableList);


}


输出:

Unmodifiable Collection: [Apple, Banana, Cherry]
Cannot modify unmodifiable collection: null
Modified Original Collection: [Apple, Banana, Cherry, Date]
Unmodifiable Collection after original modification: [Apple, Banana, Cherry, Date]


CheckedCollection 集合
用于创建一个集合,在创建的时候指定元素类型。该集合会在添加或修改元素时进行类型检查,若类型检查不通过将抛异常。

public static void main(String[] args) {
    // 创建一个可修改的集合
    Collection<String> stringList = new ArrayList<>();

    // 创建一个类型安全的集合,指定只能包含 String 类型的元素
    Collection<String> checkedCollection = Collections.checkedCollection(stringList, String.class);

    // 添加元素
    checkedCollection.add("Apple");
    checkedCollection.add("Banana");

    // 输出集合内容
    System.out.println("Checked Collection: " + checkedCollection);

    // 尝试添加不匹配的类型
    try {
        // 将抛出 ClassCastException
        checkedCollection.add((String) (Object) 123); // 强制转换以模拟错误
    } catch (ClassCastException e) {
        System.out.println("Caught ClassCastException: " + e.getMessage());
    }

    // 打印最终的集合内容
    System.out.println("Final Checked Collection: " + checkedCollection);
}


synchronizedCollection 方法

将指定集合包装为线程安全的对象。遍历的时候必须添加 synchronized 关键字。

public static void main(String[] args) {

    // 创建一个普通的 ArrayList
    Collection<String> list = new ArrayList<>();

    // 使用 Collections.synchronizedCollection 创建一个线程安全的集合
    Collection<String> synchronizedList = Collections.synchronizedCollection(list);


    // 添加元素到同步集合
    synchronizedList.add("Hello");
    synchronizedList.add("World");


    // 遍历集合时需要显式同步
    synchronized (synchronizedList) {
        for (String item : synchronizedList) {
            System.out.println(item);
        }
    }

}



replaceAll 方法


用于替换集合中所有出现的指定元素为新的指定元素, replaceAll 方法是直接在原集合上进行操作,因此它不会返回一个新的集合, 替换操作是基于 equals 方法进行的,因此要确保 oldVal 的类型与集合中的元素类型相同。

public static void main(String[] args) {
    // 创建一个包含多个元素的列表
    List<String> fruits = new ArrayList<>();
    fruits.add("Apple");
    fruits.add("Banana");
    fruits.add("Apple");
    fruits.add("Orange");


    // 输出原始列表
    System.out.println("Original List: " + fruits);


    // 替换所有 "Apple" 为 "Mango"
    Collections.replaceAll(fruits, "Apple", "Mango");


    // 输出替换后的列表
    System.out.println("Updated List: " + fruits);
}









【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。