Comparable与Comparator区别

接口 Comparable<T>  此接口强调对实现它的每个类的对象进行强加一个整体排序, 被称为类的自然排序(类自己拥有排序方法)

实现Comparable<T>接口重写comparaTo(T o)方法(有自然顺序的就没必要重写了)

public class Student implements Comparable<Student> {
	private String name;
	private String age;
	public Student(String name, String age) {
		super();
		this.name = name;
		this.age = age;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public String getAge() {
		return age;
	}
	public void setAge(String age) {
		this.age = age;
	}
	@Override
	public int compareTo(Student o) {
		// TODO Auto-generated method stub
		int i=	Integer.valueOf(this.age);
		int	j=Integer.valueOf(o.age);
		if(i<j){
			return -1;
		}else if(i>j){
			return 1;
		}else{
		return 0;
		}
	}	

 

接口Comparator<T> 重写compare(T o,T o1) 对一些对象的集合施加了一个整体排序比较器传递给排序方法(如Collections.sortArrays.sort )以便对排序顺序进行精确控制。

public class ComparatorDemo implements Comparator<Student>{
	@Override
	public int compare(Student o1, Student o2) {
		// TODO Auto-generated method stub
		if(o1==null||o2==null){
			return 0;
		}
		int i=	Integer.valueOf(o1.getAge());
		int	j=Integer.valueOf(o2.getAge());
		if(i<j){
			return -1;
		}else if(i>j){
			return 1;
		}else{
		return 0;
		}
	}

 

猜你喜欢

转载自blog.csdn.net/Hello_word_2/article/details/81487250