天天看点

JAVA自定义比较器Comparator 和 Comparable

JAVA有两种比较器,分别是:Comparator 和 Comparable

我看网上说Comporable是内部比较器,而Comparator是外部比较器,由于这两个都是接口,所以都需要去实现,而实现Comporable接口则需要实现compareTo方法,实现Comparator需要实现compare方法。Comparable接口一般由要比较的类实现,所以叫内部比较器,而comparator比较器一般是单独实现,或者匿名内部类实现。

例如:

public class Person implements Comparable<Person> {
	int age;
	public Person(int age) {
		this.age = age;
	}
	@Override
	public int compareTo(Person person) {
		// TODO Auto-generated method stub
		return this.age - person.age;
	}
}
           

测试代码:

public class TestComparator {
public static void main(String[] args) {
		List<Person> list = new ArrayList<>();
		list.add(new Person(12));
		list.add(new Person(9));
		list.add(new Person(10));
		list.add(new Person(22));
		System.out.println("排序前:");
		for (int i = 0; i < list.size(); i++) {
			System.out.print(list.get(i).age + "  ");
		}
		System.out.println("排序后:");
		Collections.sort(list);
		for (int i = 0; i < list.size(); i++) {
			System.out.print(list.get(i).age + "  ");
		}
	}
}
           

运行结果:

排序前:
12  9  10  22  
排序后:
9  10  12  22  
           

自定义比较器:

public class myComparator implements Comparator<Person> {

	@Override
	public int compare(Person p1, Person p2) {
		// TODO Auto-generated method stub
		return p2.age - p1.age;
	}

}
           

然后在比较的时候把它给传过去:

//接上面的测试方法
	System.out.println("\n" + "使用自定义比较器排序后:");
		Collections.sort(list, new myComparator());
		for (int i = 0; i < list.size(); i++) {
			System.out.print(list.get(i).age + "  ");
		}
           

运行结果如下:

排序前:
12  9  10  22  
排序后:
9  10  12  22  
使用自定义比较器排序后:
22  12  10  9  
           

综上,两者的区别是实现Comparator接口代码更加灵活,可以定义某个类的多个比较器,从而在排序时根据实际场景自由调用,而Comparable接口实现后便不能改动