/*
Collections:操作Collection、Map的工具类
面试题:Collections和Collection的区别?
*/
public class CollectionsTest {
/*
排序操作:(均为static方法)
reverse(List):反转List中元素的顺序
shuffle(List):对List集合元素进行随机排序
sort(List):根据元素的自然顺序对指定List集合元素按升序排序
sort(List,Comparator):根据指定的Comparator产生的顺序对List集合元素进行排序
swap(List,int,int):将指定list集合中的i处元素和j处元素进行交换
查找、替换
Object max(Collection):根据元素的自然顺序,返回给定集合中的最大元素
Object max(Collection,Comparator):根据Comparator指定的顺序,返回给定集合中的最大元素
Object min(Collection)
Object min(Collection,Comparator)
int frequency(Collection,Object):返回指定集合中指定元素的出现次数
void copy(List dest,List src):将src中的内容复制到dest中
boolean replaceAll(List list,Object oldVal,Object newVal):使用新值替换List对象的所有旧值
*/
@Test
public void test1(){
List list = new ArrayList();
list.add(123);
list.add(43);
list.add(765);
list.add(-97);
list.add(0);
System.out.println(list);//[123, 43, 765, -97, 0]
Collections.reverse(list);
System.out.println(list);//[0, -97, 765, 43, 123]
Collections.shuffle(list);
System.out.println(list);//[43, 0, 765, -97, 123]
Collections.sort(list);
System.out.println(list);//[-97, 0, 43, 123, 765]
Collections.swap(list,0,1);
System.out.println(list);//[0, -97, 43, 123, 765]
}
@Test
public void test2(){
List list = new ArrayList();
list.add(123);
list.add(43);
list.add(369);
list.add(369);
list.add(369);
list.add(-97);
list.add(0);
int frequency = Collections.frequency(list,369);
System.out.println(frequency);//3
//报异常:IndexOutOfBoundsException: Source does not fit in dest
// List dest = new ArrayList();
//
// Collections.copy(dest,list);
List dest = Arrays.asList(new Object[list.size()]);
System.out.println(dest.size());//list.size();
Collections.copy(dest,list);
System.out.println(dest);//[123, 43, 369, 369, 369, -97, 0]
}
/*
Collections类中提供了多个synchronizedXxx()方法,该方法可将指定集合包装成线程同步的集合
从而可以解决多线程并发访问集合时的线程安全问题
*/
@Test
public void test3(){
List list = new ArrayList();
list.add(123);
list.add(43);
list.add(369);
list.add(369);
//返回的list1即为线程安全的list
List list1 = Collections.synchronizedList(list);
}
}
[集合]Collections工具类常用方法的测试
最新推荐文章于 2026-01-01 15:39:09 发布
本文介绍了Java Collections类提供的排序、查找、替换及线程安全操作方法,如reverse、shuffle、sort、swap等,并通过示例展示了如何在实际场景中使用这些工具。

435

被折叠的 条评论
为什么被折叠?



