Java Review (三十、集合----- 操作集合的工具类: Collections)

简介: Java Review (三十、集合----- 操作集合的工具类: Collections)

     

文章目录

Java 提供了一个操作 Set 、 List 和 Map等集合的类:Collections , 该工具类里提供了大量方法对集合元素进行排序、 查询和修改等操作,还提供了将集合对象设置为不可变、对集合对象实现同步控制等方法 。

排序操作

Collections 提供了如下常用的类方法用于对 List 集合元素进行排序 。

  • void reverse(List list): 反转指定 List 集合中元素的顺序 。
  • void shuffie(List list): 对 List 集合元素进行随机排序 (shuffie 方法模拟了 “洗牌” sort(List !ist): 根据元素的自然顺序对指定 List 集合的元素按升序进行排序。
  • void sort(List list, Comparator c): 根据指定 Comparator 产生 的顺序对 List 集合元素进行排序 。
  • void swap(List list, int i, int j): 将指定 List 集合中的 i 处元素和 j 处元素进行交换。
  • void  rotate(List list , int distance): 当 distance 为正数时,将 list 集合的后 distance  个元素"整体"移到前面;当 distance 为负数时,将 list 集合的前 distance 个元素"整体 "移到后面 。  该方法不会改变集合的长度 。

 下面程序简单示范了利用 Collections 工具类来操作 List 集合:

SortTest.java

public class SortTest
{
  public static void main(String[] args)
  {
    ArrayList nums = new ArrayList();
    nums.add(2);
    nums.add(-5);
    nums.add(3);
    nums.add(0);
    System.out.println(nums); // 输出:[2, -5, 3, 0]
    Collections.reverse(nums); // 将List集合元素的次序反转
    System.out.println(nums); // 输出:[0, 3, -5, 2]
    Collections.sort(nums); // 将List集合元素的按自然顺序排序
    System.out.println(nums); // 输出:[-5, 0, 2, 3]
    Collections.shuffle(nums); // 将List集合元素的按随机顺序排序
    System.out.println(nums); // 每次输出的次序不固定
  }
}

查找、替换操作

Collections 还提供了如下常用的用于查找、替换集合元素的类万法 。

  • int binarySearch(List list, Object key): 使用 二分搜索法搜索指定的 List 集合 ,以获得指定对象在 List集合中的索引。如果要使该方法可以正常工作,则必须保证 List 中的元素 己经处于有序状态 。
  • Object max(Collection coll): 根据元素 的自然顺序 ,返 回给定集合中的最大元素。
  • Object max(Collection coll, Comparator comp): 根据 Comparator 指定的顺序,返回给定集合中的最大元素 。
  • Object min(Collection coll) : 根据元素的自然顺序,返回给定集合中 的最小元素 。
  • Object min(Collection coll, Comparator comp): 根据 Comparator 指 定的顺序,返回给定集合中的最小元素 。
  • void fill(List list, Object obj): 使用指定元素 obj 替换指定 List 集合中的所有元素 。
  • int frequency(Collection c, Object o): 返回指定集合中指定元素的出现次数。
  • int indexOfSubList(List source, List target) : 返回子 List 对象在父 List 对象中第一次 出现的位置索引:如果父 List 中没有出现这样的子 List,则返回口一 1 。
  • int lastIndexOfSubList(List source, List target): 返回子 List 对象在父 List 对象中最后一 次出现的位置索引 ;如果父 List 中 没有出现这样的子 List,则返回 口 -l 。
  • boolean replaceAll(List list, Object oldVal, Object newVal): 使用一个新值 newVal 替换 List 对象的所有旧值oIdVal 。

 下面程序简单示范了 Collections 工具类的用法 。

SearchTest.java

public class SearchTest{
  public static void main(String[] args){
    ArrayList nums = new ArrayList();
    nums.add(2);
    nums.add(-5);
    nums.add(3);
    nums.add(0);
    System.out.println(nums); // 输出:[2, -5, 3, 0]
    System.out.println(Collections.max(nums)); // 输出最大元素,将输出3
    System.out.println(Collections.min(nums)); // 输出最小元素,将输出-5
    Collections.replaceAll(nums , 0 , 1); // 将nums中的0使用1来代替
    System.out.println(nums); // 输出:[2, -5, 3, 1]
    // 判断-5在List集合中出现的次数,返回1
    System.out.println(Collections.frequency(nums , -5));
    Collections.sort(nums); // 对nums集合排序
    System.out.println(nums); // 输出:[-5, 1, 2, 3]
    //只有排序后的List集合才可用二分法查询,输出3
    System.out.println(Collections.binarySearch(nums , 3));
  }
}

同步控制

Collections 类中提供了多个 synchronizedXxxO方法,该方法可以将指定集合包装成线程同步的集合,从而可以解决多线程并发访问集合时的线程安全问题。

Java 中 常用的集合框架中的实现类 HashSet 、 TreeSet 、ArrayList 、 ArrayDeque 、  LinkedList 、 HashMap和 TreeMap 都是线程不安全的 。  如果有多个线程访问它们,而且有超过一个的线程试图修改它们,则存在线程安全的问题。 Collections  提供了多个类方法可以把它们包装成线程同步的集合。

 下面的示例程序创建了 4 个线程安全的集合对象:

SynchronizedTest.java

public class SynchronizedTest
{
  public static void main(String[] args)
  {
    // 下面程序创建了四个线程安全的集合对象
    Collection c = Collections
      .synchronizedCollection(new ArrayList());
    List list = Collections.synchronizedList(new ArrayList());
    Set s = Collections.synchronizedSet(new HashSet());
    Map m = Collections.synchronizedMap(new HashMap());
  }
}

设置不可变集合

Co llections 提供了如下三类方法来返回一个不可变的集合。

  • emptyXxx(): 返回 一个空的 、 不可变 的集合对象,此处的集合既可以是 List , 也可以 是 SortedSet 、Set , 还可以是 M ap 、 SortedMap 等。
  • singletonXxx() : 返回一个只包含指定对象(只有一个或一项元素)的、不可变的集合对象, 此处的集合既可以是 List,还可以是 Map 。
  • unmodifiableXxx() : 返回指定集合对象的不可变视图,此处的集合既可以是 List ,也可 以 是 Set 、SortedSet , 还可以是 Map 、 SorteMap 等。

上面三类方法的参数是原有的集合对象 , 返回值是该集合的"只读 " 版本 。 通过 Collections 提供的三类方法,可以生成"只读"的 Collection 或 Map。如下 :

UnmodifiableTest.java

public class UnmodifiableTest
{
  public static void main(String[] args)
  {
    // 创建一个空的、不可改变的List对象
    List unmodifiableList = Collections.emptyList();
    // 创建一个只有一个元素,且不可改变的Set对象
    Set unmodifiableSet = Collections.singleton("疯狂Java讲义");
    // 创建一个普通Map对象
    Map scores = new HashMap();
    scores.put("语文" , 80);
    scores.put("Java" , 82);
    // 返回普通Map对象对应的不可变版本
    Map unmodifiableMap = Collections.unmodifiableMap(scores);
    // 下面任意一行代码都将引发UnsupportedOperationException异常
    unmodifiableList.add("测试元素");   //①
    unmodifiableSet.add("测试元素");    //②
    unmodifiableMap.put("语文" , 90);   //③
  }
}

集合总结

image.png


参考:

【1】:《疯狂Java讲义》

【2】:廖雪峰的官方网站:使用Collections

【3】:微信公众号:Java思维导图


目录
相关文章
|
27天前
|
存储 安全 Java
java.util的Collections类
Collections 类位于 java.util 包下,提供了许多有用的对象和方法,来简化java中集合的创建、处理和多线程管理。掌握此类将非常有助于提升开发效率和维护代码的简洁性,同时对于程序的稳定性和安全性有大有帮助。
47 17
|
19天前
|
Java
Java 8 引入的 Streams 功能强大,提供了一种简洁高效的处理数据集合的方式
Java 8 引入的 Streams 功能强大,提供了一种简洁高效的处理数据集合的方式。本文介绍了 Streams 的基本概念和使用方法,包括创建 Streams、中间操作和终端操作,并通过多个案例详细解析了过滤、映射、归并、排序、分组和并行处理等操作,帮助读者更好地理解和掌握这一重要特性。
25 2
|
24天前
|
存储 Java
判断一个元素是否在 Java 中的 Set 集合中
【10月更文挑战第30天】使用`contains()`方法可以方便快捷地判断一个元素是否在Java中的`Set`集合中,但对于自定义对象,需要注意重写`equals()`方法以确保正确的判断结果,同时根据具体的性能需求选择合适的`Set`实现类。
|
19天前
|
安全 Java
Java多线程集合类
本文介绍了Java中线程安全的问题及解决方案。通过示例代码展示了使用`CopyOnWriteArrayList`、`CopyOnWriteArraySet`和`ConcurrentHashMap`来解决多线程环境下集合操作的线程安全问题。这些类通过不同的机制确保了线程安全,提高了并发性能。
|
24天前
|
存储 Java 开发者
在 Java 中,如何遍历一个 Set 集合?
【10月更文挑战第30天】开发者可以根据具体的需求和代码风格选择合适的遍历方式。增强for循环简洁直观,适用于大多数简单的遍历场景;迭代器则更加灵活,可在遍历过程中进行更多复杂的操作;而Lambda表达式和`forEach`方法则提供了一种更简洁的函数式编程风格的遍历方式。
|
24天前
|
Java 开发者
|
23天前
|
存储 Java 开发者
Java中的集合框架深入解析
【10月更文挑战第32天】本文旨在为读者揭开Java集合框架的神秘面纱,通过深入浅出的方式介绍其内部结构与运作机制。我们将从集合框架的设计哲学出发,探讨其如何影响我们的编程实践,并配以代码示例,展示如何在真实场景中应用这些知识。无论你是Java新手还是资深开发者,这篇文章都将为你提供新的视角和实用技巧。
22 0
|
Java Android开发
WSDL2Java操作指南
1. 安装JDK1.5, 配置系统环境变量:     下载安装JDK后, 设置环境变量:     JAVA_HOME=C:\Program Files\Java\jdk1.5.0_02     Path=%Path%;%JAVA_HOME%\bin(这里的%Path%指你系统已经有的一系列配置)     CLASSPATH=%JAVA_HOME%\lib  2. 下载axis,
1427 0
|
13天前
|
Java 开发者
Java多线程编程中的常见误区与最佳实践####
本文深入剖析了Java多线程编程中开发者常遇到的几个典型误区,如对`start()`与`run()`方法的混淆使用、忽视线程安全问题、错误处理未同步的共享变量等,并针对这些问题提出了具体的解决方案和最佳实践。通过实例代码对比,直观展示了正确与错误的实现方式,旨在帮助读者构建更加健壮、高效的多线程应用程序。 ####
|
4天前
|
缓存 Java 开发者
Java多线程编程的陷阱与最佳实践####
本文深入探讨了Java多线程编程中常见的陷阱,如竞态条件、死锁和内存一致性错误,并提供了实用的避免策略。通过分析典型错误案例,本文旨在帮助开发者更好地理解和掌握多线程环境下的编程技巧,从而提升并发程序的稳定性和性能。 ####