java Collections和Arrays工具类

一集合的工具类(Collections):
笔试题:

说出Collection与Collections的区别?
1.Collection是一个单列集合跟接口,Collections是一个操作集合的工具类

Collections常见方法:

对list集合排序

sort(list);
sort(list,comparator)

对list进行二分法查找

int binarySearch(list,key);
int binarySearch(list,key,Comparator);

按照指定比较器进行排序

 max(Collection);
 max(Collection,comparator);
 min(Collection);
 min(Collection,comparator);

*对list集合进行反转 *

 reverse(list);

将不同步的集合变为同步的集合

 Set synchronizedSet(SET<t> s)
 Map synchronizedMaP(Map<K,V> m)
 List synchronizedList(List<T> list)
public class Test {
    public static void main(String args[]){
        ArrayList <Integer> list = new ArrayList<Integer>();
        list.add(1);
        list.add(123);
        list.add(3);
        list.add(12);
        list.add(23);
        
        //排序
        Collections.sort(list);
        System.out.println("排序后元素为:"+list);
        
        //查找
        System.out.println("找到的位置是:"+Collections.binarySearch(list, 123));
        
        //最大值
        System.out.println("最大值是:"+Collections.max(list));
        
        //反转
        Collections.reverse(list);
        System.out.println("反转后无素为:"+list);
    }   
}
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;

class Student{
    int id;
    String name;
    public Student(int id,String name){
        this.id = id;
        this.name = name;
    }
    
    @Override
    public String toString() {
        // TODO Auto-generated method stub
        return String.format("编号:%d 姓名:%s\n",id,name);
    }
}

class MyComparator implements Comparator<Student>{
    @Override
    public int compare(Student o1, Student o2) {
        return o1.id - o2.id;
    }
}

public class Demo02 {

    public static void main(String[] args) {
        ArrayList <Student> list = new ArrayList<Student> ();
        list.add(new Student(3,"丁昌江"));
        list.add(new Student(2,"熊尚旭"));
        list.add(new Student(1,"吴云飞"));
        
        //排序
        Collections.sort(list,new MyComparator());
        System.out.println("排序后元素为:"+list);
        
        //查找
        System.out.println("查找到的位置是:"+Collections.binarySearch(list,new Student(1,"马云"),new MyComparator()));
        /*因为比较器的原因,只要编号一样就视为找到了*/
        
        //反转
        Collections.reverse(list);//反转是不依赖比较器的哟!
        System.out.println("反转后无素为:"+list);
        
    }
}
二:集合的工具类Arrays:
Arrays常见方法:

二分查找:

binarySearch(int[]);
binarySearch(double[]);

数组排序

sort(int [])
sort(char[])

将数组变成字符串

toString(int []);

复制数组

copyOf(int/boolean...[] original,int newLength);
    original:源数组
    newLenght:新数组长度

复制部分数组

copyOfRange(int/float[]... original, int from, int to)

比较两个数组是否相同

equals(int[],int[]);

将数组变成集合

List asList(T[]);
public class Test02 {

    public static void main(String[] args) {
        int a[] = {1,3,2,6};
        int b[] = Arrays.copyOf(a,4);
        int c[] = Arrays.copyOfRange(a, 1, 4);
        
        System.out.println(Arrays.toString(b));
        System.out.println(Arrays.toString(c));
        
        System.out.println("比较两个数组:"+Arrays.equals(a, b));//true
        /*两个数组的比较,只有内容,容量,顺序一样才是true*/
        
        Integer[] d1= {1,2,3,4};
        List list = Arrays.asList(d1);
        for (int i = 0; i < list.size();i++){
            System.out.println(list.get(i)+"");
        }
        /*
            这里如果接收的是基本数据类型的数组,那么相当于只是存储了int[]这个类型,容量是1
            一般是使用包装类Integer
         */
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Java 语言支持的类型分为两类:基本类型和引用类型。整型(byte 1, short 2, int 4, lon...
    xiaogmail阅读 1,369评论 0 10
  • 1.Java集合框架是什么?说出一些集合框架的优点? 每种编程语言中都有集合,最初的Java版本包含几种集合类:V...
    独念白阅读 823评论 0 2
  • java笔记第一天 == 和 equals ==比较的比较的是两个变量的值是否相等,对于引用型变量表示的是两个变量...
    jmychou阅读 1,524评论 0 3
  • 1. Collections工具类 1.1 Collections类概述 针对集合操作 的工具类,里面的方法都是静...
    JackChen1024阅读 249评论 0 0
  • 今天,来北京整整一年。 去年的今天北京也下着雨,下了火车顶着大雨匆匆上了地铁,稀里糊涂花200块找了个住的地方,那...
    猛哥不小心阅读 272评论 5 0