java_comparable接口

在数组中,我们可以直接使用Arrays类对数据进行排序操作 。而且Arrays类的srot方法被重载多次,可以对任意类型的数组进行排序,排列时会根据数值的大小进行排序。同样,它也可以对Object数组进行排序,但是有一个要求,即对象所在的类必须实现Comparable接口。

Comparable接口的定义如下:

public interface Comparable<T>{
    public int compareTo(T o);
}

int的值有一下三种:

  • 1 表示大于
  • -1 表示小于
  • 0 表示相等

下面来看一个实例:要求设计一个学生类,此类包括姓名,年龄,成绩三个字段,并产生一个对象数组,要求按照成绩从高到低排序,如果成绩相同,则按年龄从低到高排序。

student类:

public class Student implements  Comparable<Student>{
    private String name;
    private int age;
    private int score;

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

    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;
    }

    public int getScore() {
        return score;
    }

    public void setScore(int score) {
        this.score = score;
    }

    public String toString() {
        return name+"\t\t"+age +"\t\t"+ score;
    }

    @Override
    public int compareTo(Student o) {
        if(this.score > o.score){
            return -1;
        }else if(this.score<o.score){
            return 1;
        }else {
            if(this.age>o.age){
                return 1;
            }else if(this.age<o.age){
                return  -1;
            }else {
                return 0;
            }
        }

    }
}

测试类:

public class StudentTest {

    public static void main(String[] args) {
        Student stu[] = {new Student("张三",24,99),
                new Student("李四",22,100),
                new Student("王五",19,30),
                new Student("赵七",20,99),
                new Student("孙八",43,23)};

        Arrays.sort(stu);

        for (Student s :stu){
            System.out.println(s);
        }
    }
}

运行结果:

李四 22 100
赵七 20 99
张三 24 99
王五 19 30
孙八 43 23

发布了22 篇原创文章 · 获赞 9 · 访问量 3万+

猜你喜欢

转载自blog.csdn.net/qq_19408473/article/details/72920074