另一种比较器:Comparator

package comparatordemo.cn;

import java.util.Comparator;

/*
 * 一个对象的初期,并没有实现comparable 接口,此时肯定无法进项对象的排序操作,所以为了解决这个问题,
 * Java又定义了另一个比较器的操作接口,但是前提是:必须先定义好一个比较规则类出来
 * 接口的定义如下:
 * public interface Comparator<T>{
 * public int compare(T o1, T o2) ;
 * boolean equals(Object obj) ;
 *}
 */
//定义一个person类
 class Person{
     private String name;
     private int age;
    public Person(String name, int age) {
        super();
        this.name = name;
        this.age = age;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
     //复写equals方法
    public boolean equals(Object obj){
        if (this==obj) {
            return true;
        }
        if (!(obj instanceof Person)) {
            return false;
        }
        Person p = (Person)obj;
        if (this.age==p.age&&this.name.equals(p.name)) {
            return true;
        }
        else {
            return false;
        }
        
    }
    //重写tostring方法
            public String toString(){
                return this.getName()+this.getAge();
            }
    
 }
 //定义一个比较规则
 class PersonComparator implements Comparator<Person>{
     public int compare(Person p1, Person p2){
         if (p1.equals(p2)) {
            return 0;
        }
         else if (p1.getAge()<p2.getAge()) {
            return 1;
        }
         else {
            return -1;
        }    
     }
 }
 
public class ComparatorDemo {
    public static void main(String[] args) {
        //创建一个对象数组
        Person stu[] = {new Person("张三",22),new Person("张三",20),new Person("李四",22),new Person("王五",30),new Person("赵六",40)};
         //排序
         java.util.Arrays.sort(stu,new PersonComparator());
         //遍历数组
         for (int i = 0; i < stu.length; i++) {
            System.out.println(stu[i]);
        }
    }

}

 

posted @ 2017-06-05 14:38  初学者,方圆几里  阅读(292)  评论(0编辑  收藏  举报