Collections集合工具类-JAVA

  • java.util.Collections:是个集合工具类
  • 它不是集合,而是集合的工具类

常用 API:
Collections集合工具类-JAVA_第1张图片
注意 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]

你可能感兴趣的:(java,开发语言)