每日学习07:Comparable接口的CompareTo的用法

9 篇文章 1 订阅

接口 Comparable:

此接口强行对实现它的每个类的对象进行整体排序。这种排序被称为类的自然排序,类的 compareTo 方法被称为它的自然比较方法。 字符串 数组列表 数组

所有可以 “排序” 的类都实现了java.lang.Comparable接口Comparable接口中只有一个方法。
public int compareTo(Object obj) ;该方法
返回 0 表示 this == obj
返回整数表示 this > obj
返回负数表示 this < ob
实现了 Comparable 接口的类通过实现 comparaTo 方法从而确定该类对象的排序方式。compareTo就比较用来比较两个值,如果前者大于后者,返回1,等于返回0,小于返回-1。
该接口强行对实现它的每个类的对象进行整体排序。此排序被称为该类的自然排序 ,类的 compareTo 方法被称为它的自然比较方法 。

实现此接口的对象列表和数组可以通过 Collections.sort (和 Arrays.sort )进行自动排序。如Jdk 中 Long 根据 value 大小进行排序

1.实现此接口的对象列表(和数组)可以通过 Collections.sort(和 Arrays.sort)进行自动排序。
2.实现此接口的对象可以用作有序映射中的键或有序集合中的元素,无需指定比较器。

一个类若要实现Comparable接口,必须要override里面的compareTo方法

public class Circle implements Comparable<Circle>{
    private double radius;
    public Circle(){

    }

    public Circle(double radius){
        this.radius = radius;
    }

    public double getPerimeter(){ //求周长方法
        return 2*radius*Math.PI;
    }

    public double getArea(){ //求面积方法
        return radius*radius*Math.PI;
    }

    @Override //要实现Comparable接口中的CompareTo方法
    public int compareTo(Circle o) {
        if(this.getArea() > o.getArea())
            return 1;
        else if(this.getArea()<o.getArea())
            return -1;
        else
            return 0;
    }

    public static void main(String[] args){
        //Circle circle = new Circle();
        Circle[] circles = new Circle[]{
            new Circle(3.4),new Circle(2.5),new Circle(5.8)
        };
        System.out.println(circles[0].compareTo(circles[1]));
        System.out.println(circles[1].compareTo(circles[2]));
    }

}


  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
很好的问题!让我来解答。 首先,让我们来了解一下 `Comparable` 接口。这个接口Java 中的一个接口,它只有一个方法 `compareTo()`。这个方法的作用是定义类的自然排序顺序。 如果我们要对一个对象集合进行排序,只需要让这个类实现 `Comparable` 接口,并且重写 `compareTo()` 方法。这个方法返回一个整型值,表示该对象与另一个对象的大小关系。如果该对象小于另一个对象,则返回负整数;如果两个对象相等,则返回零;如果该对象大于另一个对象,则返回正整数。 下面是一个简单的例子,展示如何使用 `Comparable` 接口进行排序。 ```java public class Student implements Comparable<Student> { private String name; private int age; public Student(String name, int age) { this.name = name; this.age = age; } public String getName() { return name; } public int getAge() { return age; } // 重写 compareTo 方法 @Override public int compareTo(Student o) { // 按照年龄从小到大排序 return this.age - o.getAge(); } } ``` 在这个例子中,我们定义了一个 `Student` 类,并且让它实现了 `Comparable` 接口。我们重写了 `compareTo()` 方法,按照年龄从小到大排序。 现在,我们可以使用 `Collections.sort()` 方法对 `Student` 对象进行排序了: ```java List<Student> students = new ArrayList<>(); students.add(new Student("Tom", 20)); students.add(new Student("Jerry", 18)); students.add(new Student("Alice", 22)); Collections.sort(students); for (Student student : students) { System.out.println(student.getName() + " " + student.getAge()); } ``` 输出结果为: ``` Jerry 18 Tom 20 Alice 22 ``` 可以看到,我们成功地按照年龄从小到大对 `Student` 对象进行了排序。 希望这个例子能够帮助你理解如何使用 `Comparable` 接口进行排序。如果你还有其他问题,请随时提出!

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值