comparable 的方法是让所要被存储的对象所属于的类自己有排序的功能, 但是 有些情况我们不能对这个类进行修改,只是将该类的对象进行存储
另一种方法 : 让集合具有比较功能, 当添加一个元素的时候集合将这个元素进行比较,然后存放。(这种方式使用较多)
comparator 接口
1. 定义一个类 实现comparator接口
2. 覆盖该接口的compare方法
3 . 将该类的对象作为参数传递给集合(如 TreeSet)的构造函数
eg :
比较器的类:
class com implements comparator
{
public int compare(object obj)
{
Person p = (Person)obj;
int temp = this.age - p.age;
return temp==0?this.name.compareTo(p.name):temp;
}// 这个比较器的比较方法是 按照年龄排序,年龄相同时按姓名排序
}
所要存放的对象的类:
class Person
{
int age;
String name;
Person(String name , int age)
{
this.name = name;
this .age = age ;
}
}
main函数所在的类:
class Demo
{
public static void main(String[] args)
{
TreeSet t = new TreeSet(new com()); // 调用TreeSet集合的构造函数的时候传递一个比较器进去,使该集合具有比较功能。
// 每个集合都有一个接收一个比较器参数的构造函数
Person p1 = new Person("kk",45);
Person p2 = new Person("dd",45);
t.add(p1);
t.add(p2);
// 添加之后集合自动对添加进来的元素进行比较器中指定方法的排序 。 这个例子中是按照年龄排序,年龄相同时按姓名排序
}
}