Collections工具類
Collections工具類
- Collections是一個操作Set、List和Map等集合的工具類(類似於Arrays操作數組的工具類)
- 提供了一系列的靜態方法(static)
排序操作的相關方法
-
reverse(List)
反轉List中元素的順序
List list = new ArrayList(); list.add(-92); list.add(123); list.add(963); list.add(100); list.add(-8); list.add(20); System.out.println(list);//[-92, 123, 963, 100, -8, 20] Collections.reverse(list); System.out.println(list);//[20, -8, 100, 963, 123, -92]
-
shuffle(List)
對List集合元素進行隨機排序
Collections.shuffle(list); System.out.println(list);//[963, -8, 123, 100, -92, 20]
-
sort(List)
根據元素的自然排序對指定的List集合元素按升序排序
Collections.sort(list); System.out.println(list);//[-92, -8, 20, 100, 123, 963]
-
sort(List , Comparator)
根據指定的Comparator產生的順序對List集合元素進行排序
-
swap(List , int i , int j)
將指定的List集合中的i處元素和j處元素驚醒交換
//交換前原始的List為[-92, 123, 963, 100, -8, 20] Collections.swap(list,1,5); System.out.println(list);//[-92, 20, 963, 100, -8, 123]
查找、替換操作相關的方法
-
max(Collection)
根據元素的自然順序,返回給定集合中最大的元素
System.out.println(Collections.max(list));//963
-
max(Collection , Comparator)
根據Comparator指定的順序,返回給定集合中最大的元素
-
min(Collection)
根據元素的自然順序,返回給定集合中最小的元素
-
min(Collection , Comparator)
根據Comparator指定的順序,返回給定集合中最小的元素
-
frequency(Collection , Object)
返回指定集合中指定元素出現的次數
System.out.println(Collections.frequency(list,-8));//1
-
copy(List dest , List src)
將src中的內容複製到dest中
其中要求dest中要有src複製的位置(假如src有3個元素,這時候要求dest也要有三個位置可以存放src的三個元素)
不可以直接複製,會報錯。
List src = new ArrayList(); src.add(-92); src.add(123); src.add(963); System.out.println("src:" + src); List dest = Arrays.asList(new Object[src.size()]); System.out.println(dest); Collections.copy(dest , src); System.out.println("dest:" + dest);
-
replaceAll(List list , Object oldjVal , Object newVal)
使用新值替換List對象中的舊值
同步控制
Collections類中提供了多個synchronizedXxx()方法,該方法可以將指定集合包裝成執行緒同步集合,從而解決多執行緒並發訪問集合時的執行緒安全問題
List list = new ArrayList();
list.add(-92);
list.add(123);
list.add(963);
List list1 = Collections.synchronizedList(list);//list1即為執行緒安全的