数组中的有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