Java 类继承Comparable列表比较

一、前言

Java 中的对象,正常情况下,只能进行比较:==  或  != 。不能使用 > 或 < 。但是在实际开发场景中,有时候需要对多个对象进行排序,言外之意,就是需要比较对象的大小。这便引出了 Comparable、Comparator 两个接口

二、Comaprable接口

Comparable 位于 java.lang.Comaprable,其源码如下:

package java.lang;
import java.util.*;
public interface Comparable<T> {
    public int compareTo(T o);
}

三、使用细节

① 实现 Comparable 接口的类必须实现 int compareTo(T o) 方法,两个对象可以通过 int compareTo(T o) 方法的返回值来比较大小:

(1)当前对象 this 大于形参对象 o,则返回正整数

(2)当前对象 this 小于形参对象 o,则返回负整数

(3)当前对象 this 等于形参对象 o,则返回 0

② 实现 Comparable 接口的对象列表或数组可以通过 Collections.sort 或 Arrays.sort 进行自动排序,无需指定 Collection.sort(...)、Arrays.sort(...) 方法的第二个比较器参数,底层会根据类中实现的 int compareTo(T o) 作为排序逻辑

③ String、八大包装类都 implements 了该接口,并实现了 int compareTo(T o) 方法,都是从小到大排列的

四、demo

4.1 类

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

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

    public String getName() {
        return name;
    }

    public int getAge() {
        return age;
    }

    @Override
    public int compareTo(Person other) {
        return Integer.compare(this.age, other.age); // Sort by age
    }

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

4.2 main函数

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

public class SortExample {
    public static void main(String[] args) {
        List<Person> people = new ArrayList<>();
        people.add(new Person("Alice", 30));
        people.add(new Person("Bob", 25));
        people.add(new Person("Charlie", 35));
        // Sort using Comparable
        Collections.sort(people);
        // Print sorted list
        System.out.println("Sorted by age:");
        for (Person person : people) {
            System.out.println(person);
        }
    }
}

 

posted @ 2025-06-06 16:19  都是城市惹的祸  阅读(2)  评论(0)    收藏  举报