java Collections工具類
陣列中的有Arrays工具類,可以對陣列操作,見我的部落格 https://mp.csdn.net/postedit/83933998
集合框架中也有跟工具類Collections,下面主要介紹其中的常用方法
基礎方法:
max(Collection<? extends T> coll) 返回集合中最大的元素,此元素類必須實現Comparable介面,並重寫compareTo方法
static void reverse(List<?> list) 對給定List進行翻轉
static void shuffle
void sort(List<T> list) 對給定List的元素進行升序排序(自然排序),元素類必須實現Comparable介面,重寫compareTo方法
static <T> int binarySearch(List<? extends Comparable<? super T>> list, T key) 對List中的元素進行二分查詢,返回索引值,如無此元素,返回-1,List要先排好序,且元素類必須實現Comparable介面,重寫compareTo方法
static void swap(List<?> list, int i, int j) List中索引i處與索引j處的元素交換位置
replaceAll(List list, Object old, Object new):替換
同步方法:
<T> Collection<T> synchronizedCollection(Collection<T> c) 根據給定集合返回一個執行緒安全的集合
<T> List<T> synchronizedList(List<T> list) 根據給定List返回一個執行緒安全的List
<K,V> Map<K,V> synchronizedMap(Map<K,V> m) 根據給定Map返回一個執行緒安全的Map
<K,V> SortedMap<K,V> synchronizedSortedMap(SortedMap<K,V> m) 根據給定SortedMap返回一個執行緒安全的SortedMap
<T> Set<T> synchronizedSet(Set<T> s) 根據給定Set返回一個執行緒安全的Set
<T> SortedSet<T> synchronizedSortedSet(SortedSet<T> s) 根據給定SortedSet返回一個執行緒安全的SortedSet
常用方法示例:
import java.util.ArrayList;
import java.util.Collections;
public class CollectionsTest01 {
public static void main(String[] args) {
ArrayList<Integer> list = new ArrayList<>();
list.add(2);
list.add(1);
list.add(4);
list.add(3);
list.add(0);
// 根據給定集合獲取最大值
System.out.println(Collections.max(list));// 4
// 反轉集合
Collections.reverse(list);
System.out.println(list);// [0, 3, 4, 1, 2]
// 隨機打亂集合中元素的順序
Collections.shuffle(list);
System.out.println(list);
// 多集合中的元素進行排序
Collections.sort(list);
System.out.println(list);// [0, 1, 2, 3, 4]
// 二分查詢集合中的元素,
System.out.println(Collections.binarySearch(list, 3));// 3
System.out.println(Collections.binarySearch(list, 15));// -6,對於沒有的元素,查詢返回不正確的值
}
}
out:
4
[0, 3, 4, 1, 2]
[2, 0, 3, 1, 4]
[0, 1, 2, 3, 4]
3
-6
參考:http://www.monkey1024.com/javase/588