转载地址:
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 排序操作
- static void reverse(List<?> list):反转指定列表中元素的顺序。
- static void shuffle(List<?> list):使用默认随机源对指定列表进行置换。即随机排序。
- static void shuffle(List<?> list, Random rnd):使用指定的随机源对指定列表进行置换。
- static
> void sort(List list):根据元素的自然顺序对指定列表按升序进行排序。 - static void sort(List list, Comparator<? super T> c):根据指定比较器产生的顺序对指定列表进行排序。
- static void swap(List<?> list, int i, int j):在指定列表的指定位置处交换元素。
- static void rotate(List<?> list, int distance):根据指定的距离轮换指定列表中的元素。即旋转,当distance为正数时,将list后distance个元素整体移到前面;当distance为负数时,将list的前distance个元素整体移到后面。
- static Comparator reverseOrder():返回一个比较器,它强行逆转实现了Comparable 接口的对象 collection 的自然顺序。
- static Comparator reverseOrder(Comparator cmp):返回一个比较器,它强行逆转指定比较器的顺序。
2.2.2 查找及替换操作
- static int binarySearch(List<? extends Comparable<? super T>>list, T key):使用二分搜索法搜索指定列表,以获得指定对象。注意,返回的是查找对象的索引,List必须是有序的。
- static int binarySearch(List<? extends T> list, T key, Comparator<?super T> c):使用二分搜索法搜索指定列表,以获得指定对象。
- static
> T max(Collection<?extends T> coll):根据元素的自然顺序,返回给定collection 的最大元素。 static T max(Collection<? extends T> coll, Comparator<? super T>comp):根据指定比较器产生的顺序,返回给定 collection 的最大元素。
- static
> T min(Collection<?extends T> coll):根据元素的自然顺序返回给定collection 的最小元素。
- static
static T min(Collection<? extends T> coll, Comparator<? super T>comp):根据指定比较器产生的顺序,返回给定 collection 的最小元素。
static void fill(List<? super T> list, T obj):使用指定元素替换指定列表中的所有元素。
static int frequency(Collection<?> c, Object o):返回指定collection 中等于指定对象的元素数。
static int indexOfSubList(List source, List target):返回指定源列表中第一次出现指定目标列表的起始位置;如果没有出现这样的列表,则返回-1。
static int lastIndexOfSubList(List source, List target):返回指定源列表中最后一次出现指定目标列表的起始位置;如果没有出现这样的列表,则返回-1。
static boolean replaceAll(List list, T oldVal, T newVal):使用另一个值替换列表中出现的所有某一指定值。
2.2.3 同步控制
Collections中几乎对每个集合都定义了同步控制方法,例如SynchronizedList(),
SynchronizedSet()等方法,来将集合包装成线程安全的集合。
static Collection synchronizedCollection(Collection c):返回指定collection 支持的同步(线程安全的)collection。
static List synchronizedList(List list):返回指定列表支持的同步(线程安全的)列表。
static
Map synchronizedMap(Map m):返回由指定映射支持的同步(线程安全的)映射。 static Set synchronizedSet(Set s):返回指定set 支持的同步(线程安全的)set。
static
SortedMap synchronizedSortedMap(SortedMap m):返回指定有序映射支持的同步(线程安全的)有序映射。 static SortedSet synchronizedSortedSet(SortedSet s):返回指定有序set 支持的同步(线程安全的)有序 set。
2.2.4 不可变(只读)的集合,以及几何相应的只读视图。
Collections提供了三类方法返回一个不可变集合,emptyXXX(),返回一个空的只读集合。
static List emptyList():返回空的列表(不可变的)。
staticMap emptyMap():返回空的映射(不可变的)。
static Set emptySet():返回空的 set(不可变的)。- singleXXX(),返回一个只包含指定对象,只有一个元素,只读的集合。
static Set singleton(T o):返回一个只包含指定对象的不可变set。
static List singletonList(T o):返回一个只包含指定对象的不可变列表。
staticMap singletonMap(K key, V value):返回一个不可变的映射,它只将指定键映射到指定值。
- singleXXX(),返回一个只包含指定对象,只有一个元素,只读的集合。
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 其他
static boolean addAll(Collection<? super T> c, T… elements):将所有指定元素添加到指定collection 中。
static void copy(List<? super T> dest, List<? extends T> src):将所有元素从一个列表复制到另一个列表。
static boolean disjoint(Collection c1, Collection c2):如果两个指定collection 中没有相同的元素,则返回 true。
static Enumeration enumeration(Collection c):返回一个指定collection 上的枚举。
static ArrayList list(Enumeration e):返回一个数组列表,它按返回顺序包含指定枚举返回的元素。
static List nCopies(int n, T o):返回由指定对象的n 个副本组成的不可变列表。
static Set newSetFromMap(Map
map):返回指定映射支持的set。 static Queue asLifoQueue(Deque deque):以后进先出(Lifo) Queue 的形式返回某个 Deque 的视图。
static Collection checkedCollection(Collection c,Class type):返回指定 collection 的一个动态类型安全视图。
static List checkedList(List list, Class type):返回指定列表的一个动态类型安全视图。
- static
Map checkedMap(Map m, Class keyType,Class valueType):返回指定映射的一个动态类型安全视图。
- static
static Set checkedSet(Set s, Class type):返回指定set 的一个动态类型安全视图。
- static
SortedMap checkedSortedMap(SortedMap m,Class keyType, Class valueType):返回指定有序映射的一个动态类型安全视图。
- static
- static SortedSet checkedSortedSet(SortedSet s, Classtype):返回指定有序 set 的一个动态类型安全视图。he