接口 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.sort或Arrays.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;
}
}