一般,Java中通过接口实现两个对象的比较,比较常用就是Comparable接口和Comparator接口。首先类要实现接口,并且使用泛型规定要进行比较的对象所属的类,然后类实现了接口后,还需要实现接口定义的比较方法,在这些方法中传入需要比较大小的另一个对象,通过选定的成员变量与之比较,如果大于则返回1,小于返回-1,相等返回0。
Comparable实现
public class People implements Comparable<People>{
private String name;
private int age;
public People(String name, int age) {
super();
this.name = name;
this.age = age;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public int compareTo(People o) {
// 按年龄从小到大排序
if(this.age > o.getAge()) {
return 1;
} else if (this.age < o.getAge()) {
return -1;
}
// 相等情况
return 0;
}
}
排序测试:
import java.util.ArrayList;
import java.util.Collections;
public class Test {
public static void main(String[] args) {
People p1 = new People("fei", 35);
People p2 = new People("qiang", 22);
People p3 = new People("sheng", 24);
ArrayList<People> list = new ArrayList<People>();
list.add(p1);
list.add(p2);
list.add(p3);
Collections.sort(list);
for(People p:list) {
System.out.println("name:"+p.getName()+", age:"+p.getAge()+"。");
}
}
}
结果:
name:qiang, age:22。
name:sheng, age:24。
name:fei, age:35。
Comparator实现
import java.util.Comparator;
public class PeopleComparator implements Comparator<People>{
@Override
public int compare(People o1, People o2) {
// 从大到小排序
if(o1.getAge() > o2.getAge()) {
return -1;
} else if (o1.getAge() < o2.getAge()) {
return 1;
}
return 0;
}
}
排序测试:
public class Test {
public static void main(String[] args) {
People p1 = new People("fei", 35);
People p2 = new People("qiang", 22);
People p3 = new People("sheng", 24);
ArrayList<People> list = new ArrayList<People>();
list.add(p1);
list.add(p2);
list.add(p3);
// 指定一个比较器
list.sort(new PeopleComparator());
for(People p:list) {
System.out.println("name:"+p.getName()+", age:"+p.getAge()+"。");
}
}
}
结果:
name:fei, age:35。
name:sheng, age:24。
name:qiang, age:22。
两种方式比较
1:Comparable是在类内部定义的方法实现的排序,Compartor是在类外部实现的排序。
2: 一个类实现了Comparable接口则表明这个类的对象之间是可以互相比较的,这个类对象组成的集合就可以直接使用sort方法排序。
3:Comparator可以看成一种算法的实现,讲算法和数据分离,可以定义多个比较器实现比如升序、降序等。