- java.util.Collections:是个集合工具类
- 它不是集合,而是集合的工具类
常用 API:
注意 binarySearch 方法要求元素有序
方法实现:
public class Test01 {
public static void main(String[] args) {
ArrayList<String>list1=new ArrayList<>();
//1.给单列集合添加元素
Collections.addAll(list1,"sdadsa","ads","b","adc","cds");
System.out.println("添加元素后: "+list1);
//2只能打乱list集合
Collections.shuffle(list1);
System.out.println("打乱元素后: "+list1);
//3.给list集合排序--按照字母大小(自然)
Collections.sort(list1);
System.out.println("自然排序后: "+list1);
//4.给list集合排序--(比较器)----
//String中默认是按照字母的abcdefg顺序进行排列的
//现在要求,按照长度排序,长度一样就按照字母大小排序
Collections.sort(list1, new Comparator<String>() {
@Override
public int compare(String o1, String o2) {
int i = o1.length() - o2.length();
if (i!=0){
return i;
}else {
return o1.compareTo(o2);//调用自然排序即按字母大小排序
}
}
});
System.out.println("指定方式排序: "+list1);
//5.二分法查找元素--前提是元素有序
ArrayList<String>list2=new ArrayList<>();
Collections.addAll(list2,"a","b","c","d");
int index = Collections.binarySearch(list2,"b" );//1
System.out.println("b的索引是:"+index);
//拷贝集合:如果list2长度>list1会报错
Collections.copy(list1,list2);//list2拷贝给list1
System.out.println("拷贝后的list1:"+list1);
//fill指定元素填充
Collections.fill(list2,"a");
System.out.println("元素填充后的list2:"+list2);
//获取最大值--按照自然排序的原则,即字母大小
String max = Collections.max(list1);
System.out.println("list1的最大字符串"+max);
//获取最小值--按照自然排序的原则,即字母大小
String min = Collections.min(list1);
System.out.println("list1的最小字符串"+min);
//交换指定索引的集合元素
Collections.swap(list1,0,4);// a<-->sdadsa
System.out.println(list1);
}
}
控制台:
添加元素后: [sdadsa, ads, b, adc, cds]
打乱元素后: [sdadsa, cds, b, adc, ads]
自然排序后: [adc, ads, b, cds, sdadsa]
指定方式排序: [b, adc, ads, cds, sdadsa]
b的索引是:1
拷贝后的list1:[a, b, c, d, sdadsa]
元素填充后的list2:[a, a, a, a]
list1的最大字符串:sdadsa
list1的最小字符串:a
交换后:[sdadsa, b, c, d, a]