1. 程式人生 > >java Collections工具類

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

(List<?> list)  打亂List中的元素在List中的位置,洗牌

 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