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); } } }
    有些事情,没经历过不知道原理,没失败过不明白奥妙,没痛苦过不了解真谛。临渊羡鱼,不如退而结网!
                    
                
                
            
        
浙公网安备 33010602011771号