下面是对自定义User对象排序的代码:
- package com.jackie.java.base;
-
- import java.util.ArrayList;
- import java.util.Collections;
- import java.util.List;
-
- public class JavaBase {
- public static void main(String[] args) {
- User user1 = new User("Jackie", 25);
- User user2 = new User("Jim", 18);
- User user3 = new User("Lucy", 30);
- User user4 = new User("Kate", 18);
-
-
-
- List<User> users = new ArrayList<>();
- users.add(user1);
- users.add(user2);
- users.add(user3);
- users.add(user4);
-
- System.out.println("排序前" );
- for (User user : users) {
- System.out.println(user.getName() + " " + user);
- }
-
- Collections.sort(users);
- System.out.println("排序后" );
- for (User user : users) {
- System.out.println(user.getName() + " " + user);
- }
- }
- }
出现了下面的异常:

很明显,Java中不允许直接对自定义的对象调用sort直接排序,需要实现Comparable接口。按照上面的方法改造一下User.java
方法一:让User对象实现Comparable接口
- package com.jackie.java.base;
-
-
-
-
- public class User implements Comparable<User> {
- private String name;
- private int age;
-
- public User() {
- }
-
- public User(String name, int age) {
- this.name = name;
- this.age = age;
- }
-
- public String getName() {
- return name;
- }
-
- public int getAge() {
- return age;
- }
-
- public void setName(String name) {
- this.name = name;
- }
-
- public void setAge(int age) {
- this.age = age;
- }
-
-
- @Override
- public int compareTo(User user) {
- return age - user.getAge();
- }
- }
调用方法:
Collections.sort(users);
方法二:User对象不作任何改动,添加一个比较器UserComparator.java
- package com.jackie.java.base;
-
- import java.util.Comparator;
-
-
-
-
- public class UserComparator implements Comparator {
- @Override
- public int compare(Object o1, Object o2) {
- User user1 = (User) o1;
- User user2 = (User) o2;
-
- if (user1.getAge() > user2.getAge()) {
- return 1;
- } else if (user1.getAge() < user2.getAge()) {
- return -1;
- } else {
-
-
- return user1.getName().compareTo(user2.getName());
- }
- }
- }
调用方法:
Collections.sort(users, new UserComparator());
结果如下:

顺便说一下Comparable和Comparator的区别:
1. Comparable和Comparator都是用来实现集合中元素的比较、排序的,只是Comparable是在集合内部定义的方法实现的排序,Comparator是在集合外部实现的排序,所以想要实现排序,就需要在集合外定义Comparator接口或在集合内实现Comparable接口两种方法。
2. Comparable实现的排序只能是自然排序,这里的自然顺序就是实现Comparable接口设定的排序方式(Demo是按照年龄从小到大排序)。而Comparator是一个专用的比较器,当这个对象不支持自比较或者自比较函数不能满足你的要求时,你可以写一个比较器来完成两个对象之间大小的比较。比如说,如果把上面的UserComparator.java的方法改为:
- public class UserComparator implements Comparator {
- @Override
- public int compare(Object o1, Object o2) {
- User user1 = (User) o1;
- User user2 = (User) o2;
-
- if (user1.getAge() > user2.getAge()) {
- return -1;
- } else if (user1.getAge() < user2.getAge()) {
- return 1;
- } else {
-
-
- return user1.getName().compareTo(user2.getName());
- }
- }
- }
输出的结果则是倒序的(年龄从大到小)

可以说一个是自已完成比较,一个是外部程序(自定义比较规则)实现比较的差别而已。