java.util.Collections --转载

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

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 的成员。

Collections类的使用

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

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

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

Collections提供以下方法对List进行操作

排序操作

  1. static void reverse(List<?> list):反转指定列表中元素的顺序。
  2. static void shuffle(List<?> list):使用默认随机源对指定列表进行置换。即随机排序。
  3. static void shuffle(List<?> list, Random rnd):使用指定的随机源对指定列表进行置换。
  4. static<T extends Comparable<? super T>> 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):返回一个比较器,它强行逆转指定比较器的顺序。

查找及替换操作

  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 extends Object & Comparable<? super T>> T max(Collection<?extends T> coll):根据元素的自然顺序,返回给定collection 的最大元素。

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

  5. static<T extends Object & Comparable<? super T>> T min(Collection<?extends T> coll):根据元素的自然顺序返回给定collection 的最小元素。

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

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

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

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

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

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

同步控制

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

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

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

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

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

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

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

不可变(只读)的集合,以及几何相应的只读视图。

  1. Collections提供了三类方法返回一个不可变集合,emptyXXX(),返回一个空的只读集合。
    static List emptyList():返回空的列表(不可变的)。
    static<K,V> Map<K,V> emptyMap():返回空的映射(不可变的)。
    static Set emptySet():返回空的 set(不可变的)。

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

  3. unmodifiablleXXX(),返回指定集合对象的只读视图。

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

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

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

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

  • static<K,V> SortedMap<K,V> nmodifiableSortedMap(SortedMap<K,? extendsV> m):返回指定有序映射的不可修改视图。

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

其他

  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<E,Boolean> 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):返回指定列表的一个动态类型安全视图。

  11. static<K,V> Map<K,V> checkedMap(Map<K,V> m, Class keyType,Class valueType):返回指定映射的一个动态类型安全视图。

  12. static Set checkedSet(Set s, Class type):返回指定set 的一个动态类型安全视图。

  13. static<K,V> SortedMap<K,V> checkedSortedMap(SortedMap<K,V> m,Class keyType, Class valueType):返回指定有序映射的一个动态类型安全视图。

  14. static SortedSet checkedSortedSet(SortedSet s, Classtype):返回指定有序 set 的一个动态类型安全视图。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值