静态成员方法:
public static <T> void sort(List<T> list) 升序
public static <T> int binarySearch(List<?> list,T key) 二分查找
public static <T> T max(Collection<?> coll)找最大值
public static void reverse(List<?> list)反转
public static void shuffle(List<?> list)随机排序
相关用法如下:
public class CollectionsDemo {
public static void main(String[] args) {
ArrayList<String> list1 = new ArrayList<>();
list1.add("hello");
list1.add("world");
list1.add("hadoop");
list1.add("apple");
System.out.println("list1: "+list1);
System.out.println("--------------------------");
Collections.sort(list1); //对List集合进行升序排序
System.out.println("list1: "+list1);
//list1: [apple, hadoop, hello, world]
//public static <T> int binarySearch(List<?> list,T key) 在针对List集合中二分查找某个元素,返回该元素的下标索引
System.out.println(Collections.binarySearch(list1,"hello"));
//public static <T> T max(Collection<?> coll)
System.out.println(Collections.max(list1));
//public static void reverse(List<?> list) 将集合元素反转
Collections.reverse(list1);
System.out.println("list1: "+list1);
//public static void shuffle(List<?> list) 将List集合元素进行随机打乱,每次运行结果都不一样
Collections.shuffle(list1);
System.out.println("list1: "+list1);
//即便Vector是线程安全的,我们今后也不用
//原因是我们可以通过Collections工具类对ArrayList或其他不安全的集合做操作,变成安全的。
List<String> list2 = Collections.synchronizedList(list1);
//后续用list2,跟不安全的用法一毛一样,没有任何区别,只是后续这个List集合是安全的了。
}
}
2、可以将不安全的集合变成安全的
static <T> Collection<T> synchronizedCollection(Collection<T> c)
返回由指定集合支持的同步(线程安全)集合。
static <T> List<T> synchronizedList(List<T> list)
返回由指定列表支持的同步(线程安全)列表。
static <K,V> Map<K,V> synchronizedMap(Map<K,V> m)
返回由指定地图支持的同步(线程安全)映射。
static <T> Set<T> synchronizedSet(Set<T> s)
返回由指定集合支持的同步(线程安全)集。
标签:synchronized,list1,List,Collections,list,线程,static,public
From: https://blog.csdn.net/ABU009/article/details/141200847