Collections和Arrays一样是一个不可实例化的类,提供了一些静态方法来操作Collection。
1.排序 sort
public static void sort(List list)
public static void sort(List list, Comparator c)
用于对List排序,可以使用自然排序,也可以指定Comparator,返回的是从小到大的有序List。
2.二分查找 binarySearch
public static int binarySearch(List list, Object key)
public static int binarySearch(List list, Object key, Comparator c)
应用和排序一样,List必须是有序的,否则改方法无作用。
3.反转
public static void reverse(List list)
适用于List,返回的List和原来的顺序相反
4.打乱顺序
public static void shuffle(List list)
public static void shuffle(List list, Random rnd)
就是把原来的List的顺序随机弄乱。
5.元素直接置换
public static void swap(List list, int i, int j)
这个方法显得有点牵强,我觉得没有必要出现在API里面,实现就是一条语句:
list.set(i, list.set(j, list.get(i)));
6.填充
public static void fill(List list, Object obj)
把List中的元素全部用一个值填充
7.拷贝
public static void copy(List dest, List src)
把源List拷贝到目的List,目的List必须足够大
8.最小值
public static Object min(Collection coll)
public static Object min(Collection coll, Comparator comp)
9.最大值
public static Object max(Collection coll)
public static Object max(Collection coll, Comparator comp)
10.移动
public static void rotate(List list, int distance)
元素右移,有点像 int a=0xff>>8的味道
11.替换
public static boolean replaceAll(List list, Object oldVal, Object newVal)
看方法名就知道了
12.求子List
public static int indexOfSubList(List source, List target)
public static int lastIndexOfSubList(List source, List target)
和String类的indexOf和lastIndexOf类似
13.同步
public static Collection synchronizedCollection(Collection c)
public static List synchronizedList(List list)
public static Map synchronizedMap(Map m)
public static Set synchronizedSet(Set s)
public static SortedMap synchronizedSortedMap(SortedMap m)
public static SortedSet synchronizedSortedSet(SortedSet s)
因为Collection框架中的类大部分都是未经过同步的,可以通过这些方法同步
注意这里没有使用方法重载,因为那么命名不同。另外,返回的虽然是一个同步了的Collection
但是通过迭代器访问时仍然需要自己同步,因为迭代器返回没有被同步。
14.只读
public static Collection unmodifiableCollection(Collection c)
public static List unmodifiableList(List list)
public static Map unmodifiableMap(Map m)
public static Set unmodifiableSet(Set s)
public static SortedMap unmodifiableSortedMap(SortedMap m)
public static SortedSet unmodifiableSortedSet(SortedSet s)
这些方法返回一个只读的Collection,我发现这个有的时候真的特别有用,如果你试图调用修改
方法,会获得一个UnsupportedOperationException系统异常。
15.常量
public static final List EMPTY_LIST = new EmptyList()
public static final Map EMPTY_MAP = new EmptyMap()
public static final Set EMPTY_SET = new EmptySet()
这些常量就是表示空的集合,本身不是null,但是不包含任何元素。
16.单元素集合
public static Set singleton(Object o)
public static List singletonList(Object o)
public static Map singletonMap(Object key, Object value)
这些集合只含有一个元素。
17.多元素集合
public static List nCopies(int n, Object o)
返回一个List,含有n个相同的元素
18.比较器常量
public static Comparator reverseOrder()
这个比较器和自然顺序的排序相反。
19.最后2个
public static ArrayList list(Enumeration e)
public static Enumeration enumeration(final Collection c)
List和Enumeration的转换,由于Enumeration属于过时的API,应该没有什么机会用到他们。
整个方法都在这里,主要是对List的操作,Set和Map的相对少一些。