共计 1004 个字符,预计需要花费 3 分钟才能阅读完成。
要实现对自定义类型排序,需要满足两个条件:
-
自定义类型需要实现
Comparable
接口,即实现compareTo
方法。该方法定义了自定义类型的排序规则。 -
使用排序算法对自定义类型的集合进行排序。
以下是示例代码:
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
方法对该集合进行排序。最后,通过遍历集合,打印出排序后的结果。
丸趣 TV 网 – 提供最优质的资源集合!
正文完