Arrays工具类的使用

Arrays类是在java.util.Arrays包下的。

import java.util.Arrays;
import java.util.Comparator;

public class Demo1 {
    public static void main(String[] args) {
        //Arrays类的使用
        int[] num = new int[]{1, 2, 56, 21, 12, 34, 22};
        System.out.println(num.length);
        System.out.println(Arrays.toString(num));//将数组内容进行打印
        Arrays.sort(num);//他返回的是空,将原数组进行升序排序
        System.out.println(Arrays.toString(num));
        System.out.println(Arrays.binarySearch(num, 56));//进行二分查找,必须要排好序的数组,不然可能找不到
        System.out.println(Arrays.binarySearch(num, 100));//如果没有这个数,他就会返回想要找的数应该在数组的索引位置的负数减一  //-8
        //同时Arrays可以自定义排序规则  但是需要数组类型是引用数据类型
        Integer[] numb = new Integer[]{13, 24, 14, 65, 34, 15};
        Arrays.sort(numb, new Comparator<Integer>() {
            @Override//匿名内部类  Comparator是一个接口
            public int compare(Integer o1, Integer o2) {
                return o1 - o2;//大的减小的 返回正值就会升序排序,大的减小的返回负值,就会降序排序
            }
        });
        System.out.println(Arrays.toString(numb));
        //同时它也可以排对象数组
        Students[] students = new Students[3];
        students[0] = new Students("zsc", 18);
        students[1] = new Students("zfy",19);
        students[2] = new Students("zr",17);
        Arrays.sort(students, new Comparator<Students>() {

            @Override
            public int compare(Students o1, Students o2) {
                return o1.getAge()-o2.getAge();
            }
        });
        System.out.println(Arrays.toString(students));

    }
}

Student类

public class Students {
    private String name;
    private int age;

    public Students() {
    }

    public Students(String name, int age) {
        this.name = name;
        this.age = age;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    @Override
    public String toString() {
        return "Students{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值