java怎么实现对自定义类型排序

avatar
作者
筋斗云
阅读量:0

要实现对自定义类型排序,需要满足两个条件:

  1. 自定义类型需要实现 Comparable 接口,即实现 compareTo 方法。该方法定义了自定义类型的排序规则。

  2. 使用排序算法对自定义类型的集合进行排序。

以下是示例代码:

import java.util.ArrayList; import java.util.Collections; import java.util.List;  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 p) {         // 根据年龄进行排序         if (this.age < p.getAge()) {             return -1;         } else if (this.age > p.getAge()) {             return 1;         } else {             return 0;         }     } }  public class Main {     public static void main(String[] args) {         List<Person> personList = new ArrayList<>();         personList.add(new Person("Alice", 25));         personList.add(new Person("Bob", 30));         personList.add(new Person("Charlie", 20));                  // 使用 Collections.sort 方法对集合进行排序         Collections.sort(personList);                  for (Person p : personList) {             System.out.println(p.getName() + " - " + p.getAge());         }     } } 

以上代码中,Person 类实现了 Comparable<Person> 接口,并重写了 compareTo 方法。在 main 方法中,首先创建了一个 Person 类型的集合 personList,然后使用 Collections.sort 方法对该集合进行排序。最后,通过遍历集合,打印出排序后的结果。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!