0%

Collection简介



转载地址:
https://blog.csdn.net/zengxiantao1994/article/details/80306669

1. Collections简介

  • public class Collections extends Object,此类完全由在 collection 上进行操作或返回 collection 的静态方法组成。它包含在collection 上操作的多态算法,即“包装器”,包装器返回由指定collection 支持的新 collection,以及少数其他内容。

  • 如果为此类的方法所提供的collection 或类对象为 null,则这些方法都将抛出NullPointerException。

  • 此类中所含多态算法的文档通常包括对实现的简短描述。应该将这类描述视为实现注意事项,而不是规范的一部分。实现者应该可以随意使用其他算法替代,只要遵循规范本身即可。(例如,sort使用的算法不一定是合并排序算法,但它必须是稳定的。)

  • 此类中包含的“破坏性”算法,即可修改其所操作的 collection 的算法,该算法被指定在collection 不支持适当的可变基元(比如 set 方法)时抛出UnsupportedOperationException。如果调用不会对collection 产生任何影响,那么这些算法可能(但不要求)抛出此异常。例如,在已经排序的、不可修改列表上调用sort 方法可能会(也可能不会)抛出 UnsupportedOperationException。

  • 此类是Java Collections Framework 的成员。

2. Collections类的使用

2.1 字段摘要
  • 1、static List EMPTY_LIST:空的列表(不可变的)。

  • 2、static Map EMPTY_MAP:空的映射(不可变的)。

  • 3、static Set EMPTY_SET:空的 set(不可变的)。
    排序操作

2.2 Collections提供以下方法对List进行操作
2.2.1 排序操作
  1. static void reverse(List<?> list):反转指定列表中元素的顺序。
  2. static void shuffle(List<?> list):使用默认随机源对指定列表进行置换。即随机排序。
  3. static void shuffle(List<?> list, Random rnd):使用指定的随机源对指定列表进行置换。
  4. static> void sort(List list):根据元素的自然顺序对指定列表按升序进行排序。
  5. static void sort(List list, Comparator<? super T> c):根据指定比较器产生的顺序对指定列表进行排序。
  6. static void swap(List<?> list, int i, int j):在指定列表的指定位置处交换元素。
  7. static void rotate(List<?> list, int distance):根据指定的距离轮换指定列表中的元素。即旋转,当distance为正数时,将list后distance个元素整体移到前面;当distance为负数时,将list的前distance个元素整体移到后面。
  8. static Comparator reverseOrder():返回一个比较器,它强行逆转实现了Comparable 接口的对象 collection 的自然顺序。
  9. static Comparator reverseOrder(Comparator cmp):返回一个比较器,它强行逆转指定比较器的顺序。
2.2.2 查找及替换操作
  1. static int binarySearch(List<? extends Comparable<? super T>>list, T key):使用二分搜索法搜索指定列表,以获得指定对象。注意,返回的是查找对象的索引,List必须是有序的。
  2. static int binarySearch(List<? extends T> list, T key, Comparator<?super T> c):使用二分搜索法搜索指定列表,以获得指定对象。
  3. static> T max(Collection<?extends T> coll):根据元素的自然顺序,返回给定collection 的最大元素。
  4. static T max(Collection<? extends T> coll, Comparator<? super T>comp):根据指定比较器产生的顺序,返回给定 collection 的最大元素。

    1. static> T min(Collection<?extends T> coll):根据元素的自然顺序返回给定collection 的最小元素。
  5. static T min(Collection<? extends T> coll, Comparator<? super T>comp):根据指定比较器产生的顺序,返回给定 collection 的最小元素。

  6. static void fill(List<? super T> list, T obj):使用指定元素替换指定列表中的所有元素。

  7. static int frequency(Collection<?> c, Object o):返回指定collection 中等于指定对象的元素数。

  8. static int indexOfSubList(List source, List target):返回指定源列表中第一次出现指定目标列表的起始位置;如果没有出现这样的列表,则返回-1。

  9. static int lastIndexOfSubList(List source, List target):返回指定源列表中最后一次出现指定目标列表的起始位置;如果没有出现这样的列表,则返回-1。

  10. static boolean replaceAll(List list, T oldVal, T newVal):使用另一个值替换列表中出现的所有某一指定值。

2.2.3 同步控制

Collections中几乎对每个集合都定义了同步控制方法,例如SynchronizedList(),
SynchronizedSet()等方法,来将集合包装成线程安全的集合。

  1. static Collection synchronizedCollection(Collection c):返回指定collection 支持的同步(线程安全的)collection。

  2. static List synchronizedList(List list):返回指定列表支持的同步(线程安全的)列表。

  3. static Map synchronizedMap(Map m):返回由指定映射支持的同步(线程安全的)映射。

  4. static Set synchronizedSet(Set s):返回指定set 支持的同步(线程安全的)set。

  5. static SortedMap synchronizedSortedMap(SortedMap m):返回指定有序映射支持的同步(线程安全的)有序映射。

  6. static SortedSet synchronizedSortedSet(SortedSet s):返回指定有序set 支持的同步(线程安全的)有序 set。

2.2.4 不可变(只读)的集合,以及几何相应的只读视图。
  1. Collections提供了三类方法返回一个不可变集合,emptyXXX(),返回一个空的只读集合。
    static List emptyList():返回空的列表(不可变的)。
    static Map emptyMap():返回空的映射(不可变的)。
    static Set emptySet():返回空的 set(不可变的)。

    1. singleXXX(),返回一个只包含指定对象,只有一个元素,只读的集合。
      static Set singleton(T o):返回一个只包含指定对象的不可变set。
      static List singletonList(T o):返回一个只包含指定对象的不可变列表。
      static Map singletonMap(K key, V value):返回一个不可变的映射,它只将指定键映射到指定值。
  2. unmodifiablleXXX(),返回指定集合对象的只读视图。

  • static Collection unmodifiableCollection(Collection<? extendsT> c):返回指定 collection 的不可修改视图。

  • static List unmodifiableList(List<? extends T> list):返回指定列表的不可修改视图。

  • static Map unmodifiableMap(Map<? extends K,? extends V>m):返回指定映射的不可修改视图。

  • static Set unmodifiableSet(Set<? extends T> s):返回指定set 的不可修改视图。

  • static SortedMap nmodifiableSortedMap(SortedMap m):返回指定有序映射的不可修改视图。

  • static SortedSet unmodifiableSortedSet(SortedSet s):返回指定有序set 的不可修改视图。

2.2.5 其他
  1. static boolean addAll(Collection<? super T> c, T… elements):将所有指定元素添加到指定collection 中。

  2. static void copy(List<? super T> dest, List<? extends T> src):将所有元素从一个列表复制到另一个列表。

  3. static boolean disjoint(Collection c1, Collection c2):如果两个指定collection 中没有相同的元素,则返回 true。

  4. static Enumeration enumeration(Collection c):返回一个指定collection 上的枚举。

  5. static ArrayList list(Enumeration e):返回一个数组列表,它按返回顺序包含指定枚举返回的元素。

  6. static List nCopies(int n, T o):返回由指定对象的n 个副本组成的不可变列表。

  7. static Set newSetFromMap(Map map):返回指定映射支持的set。

  8. static Queue asLifoQueue(Deque deque):以后进先出(Lifo) Queue 的形式返回某个 Deque 的视图。

  9. static Collection checkedCollection(Collection c,Class type):返回指定 collection 的一个动态类型安全视图。

  10. static List checkedList(List list, Class type):返回指定列表的一个动态类型安全视图。

    1. static Map checkedMap(Map m, Class keyType,Class valueType):返回指定映射的一个动态类型安全视图。
  11. static Set checkedSet(Set s, Class type):返回指定set 的一个动态类型安全视图。

    1. static SortedMap checkedSortedMap(SortedMap m,Class keyType, Class valueType):返回指定有序映射的一个动态类型安全视图。
  12. static SortedSet checkedSortedSet(SortedSet s, Classtype):返回指定有序 set 的一个动态类型安全视图。he