Compareable接口和Comparator

需求:

     做一个对象排序的功能,需要按不同规则排序

 

Compareable接口和Comparator接口都是用来实现集合排序的,只是Comparable是在集合内部定义的方法实现的排序,而Comparator是在集合外部实现的排序 ,所以,如想实现排序,就需在集合外定义Comparator接口的方法或在集合内实现Compareable接口的方法。


Comparable  是一个对象本身就已经支持自比较所需要实现的接口(如 String、Integer 自己就可以完成比较大小操作);
Comparator  是一个专用的比较器,当这个对象不支持自比较或者自比较函数不能满足你的要求时,你可以写一个比较器来完成两个对象之间大小的比较。
可以说一个是类自已完成比较,一个是外部程序实现比较的差别而已。

 

 

Compareable接口       

        要对对象进行比较大小则需要实现Compareable接口

       Compareable接口只有一个方法int compareTo(Object obj)   实现了此接口的 对象列表(或数组) 可以通过Collections.sort(Arrays.sort)来排序

Java代码 复制代码  收藏代码
  1. class Paper implements Comparable<Paper>  
  2. {  
  3.      String pcolor;  
  4.     
  5.      public Paper(String pcolor)  
  6.      {  
  7.        this.pcolor=pcolor;  
  8.      }  
  9.     
  10.      public int compareTo(Object o)//public int compareTo(Paper o)  
  11.      {  
  12.      if (o instanceof TestComparable) {  
  13.        Paper p=(Paper)o; //未使用泛型不转换的话不能访问pcolor  
  14.        int     cmp=this.pcolor.compareTo(p.pcolor);  
  15.        return cmp;  
  16.          }  
  17.      }  
  18.   //重载toString方法定义输出  
  19.      public String toString()  
  20.      {  
  21.        return this.pcolor;  
  22.      }  
  23. }  
  24.   
  25. public class TestComparable  
  26. {  
  27.      public static void main(String []args)  
  28.      {  
  29.        Paper p1=new Paper("red");  
  30.        Paper p2=new Paper("blue");  
  31.        Paper p3=new Paper("green");  
  32.        List l=new LinkedList();  
  33.        l.add(p1);  
  34.        l.add(p2);  
  35.        l.add(p3);  
  36.        Collections.sort(l);  
  37.        System.out.println(l);  
  38.      }  
  39. }  
class Paper implements Comparable<Paper>
{
     String pcolor;
  
     public Paper(String pcolor)
     {
       this.pcolor=pcolor;
     }
  
     public int compareTo(Object o)//public int compareTo(Paper o)
     {
     if (o instanceof TestComparable) {
       Paper p=(Paper)o; //未使用泛型不转换的话不能访问pcolor
       int     cmp=this.pcolor.compareTo(p.pcolor);
       return cmp;
         }
     }
  //重载toString方法定义输出
     public String toString()
     {
       return this.pcolor;
     }
}

public class TestComparable
{
     public static void main(String []args)
     {
       Paper p1=new Paper("red");
       Paper p2=new Paper("blue");
       Paper p3=new Paper("green");
       List l=new LinkedList();
       l.add(p1);
       l.add(p2);
       l.add(p3);
       Collections.sort(l);
       System.out.println(l);
     }
}

Comparator接口:

在Comparator接口里,只有一个方法是需要实现的:

 

Java代码 复制代码  收藏代码
  1. int compare(Object o1,Object o2);    
 int compare(Object o1,Object o2);  

 提示: 如果o1小于o2,返回一个负数;如果o1大于o2,返回一个正数;如果他们相等,则返回0;

注意: compare 方法一定要是对称的,意思是compare(a,b) 返回的结果要跟compare(b,a) 相反。相反的结果意味着,要么返回的值带有不同的正负号,要么都是0。注意,象compare(a,b) 返回4而compare(b,a) 返回-2这样的情况是合法的。方法里常常可能抛出异常,在这个方法里抛出异常也要是对称的。如果调用compare(a,b) 时抛出了一个ClassCastException 异常,那么调用compare(b,a) 时也必须抛出一个ClassCastException 异常。

另外: 任何你准备重用的Comparator 都必须是可序列化的。TreeSetTreeMap 类存储Comparator 以便进行比较,因此为了这两个类能被序列化,它们使用的Comparator 也必须能被序列化。

Comparator 接口,通常被Collections.sort 方法使用,它是JAVA中需要了解的一个很重要的部分

 

Java代码 复制代码  收藏代码
  1. public class Person {  
  2.     
  3.    private String name;  
  4.      private int age;  
  5.        
  6.      public Person() {        
  7.       }  
  8.   
  9.      public Person(String name, int age) {  
  10.          this.name = name;  
  11.         this.age = age;  
  12.      }  
  13.       get.set...  
  14.   
  15.      @Override  
  16.      public String toString() {  
  17.         return "Person [age=" + age + ", name=" + name + "]";  
  18.      }   
  19.  }  
public class Person {
  
   private String name;
     private int age;
     
     public Person() {      
      }

     public Person(String name, int age) {
         this.name = name;
        this.age = age;
     }
      get.set...

     @Override
     public String toString() {
        return "Person [age=" + age + ", name=" + name + "]";
     } 
 }

 新建一个实现Comparator的实现类PersonComparator:

Java代码 复制代码  收藏代码
  1. import java.util.Comparator;  
  2.   
  3. public class PersonComparator implements Comparator<Person> {  
  4.   
  5.     @Override  
  6.    public int compare(Person p1, Person p2) {  
  7.        if (p1.getAge() > p2.getAge()) {  
  8.             return 1;  
  9.        } else if (p1.getAge() < p2.getAge()) {  
  10.             return -1;  
  11.         }  
  12.         return 0;  
  13.     }       
  14. }  
 import java.util.Comparator;

 public class PersonComparator implements Comparator<Person> {

     @Override
    public int compare(Person p1, Person p2) {
        if (p1.getAge() > p2.getAge()) {
             return 1;
        } else if (p1.getAge() < p2.getAge()) {
             return -1;
         }
         return 0;
     }     
 }

 CompareTest做测试:

Java代码 复制代码  收藏代码
  1. import java.util.Arrays;  
  2.   
  3. ublic class CompareTest {  
  4.   
  5.    public static void main(String[] args) {  
  6.        Person[] persons = {  
  7.                new Person("P1"60),  
  8.                new Person("P2"20),  
  9.                new Person("P3"40)  
  10.       };    
  11.         System.out.println(Arrays.toString(persons));          
  12.   
  13.         Arrays.sort(persons, new PersonComparator());      
  14.   
  15.         System.out.println(Arrays.toString(persons));  
  16.     }   
  17. }  
 import java.util.Arrays;

public class CompareTest {
 
    public static void main(String[] args) {
        Person[] persons = {
                new Person("P1", 60),
                new Person("P2", 20),
                new Person("P3", 40)
       };  
         System.out.println(Arrays.toString(persons));        

         Arrays.sort(persons, new PersonComparator());    

         System.out.println(Arrays.toString(persons));
     } 
 }
 
Java代码 复制代码  收藏代码
  1. public class RunDemoMain {    
  2.     
  3.     public static void main(String[] args) {    
  4.         List<DataBean> dataBeans = new ArrayList<DataBean>();    
  5.         dataBeans.add(new DataBean(23"b""w"));    
  6.         dataBeans.add(new DataBean(34"e""w"));    
  7.         dataBeans.add(new DataBean(12"s""w"));    
  8.         dataBeans.add(new DataBean(10"c""w"));    
  9.   
  10.     
  11.         System.out.println("==========排序前==========");    
  12.         for (DataBean bean : dataBeans) {    
  13.             System.out.println(bean);    
  14.         }    
  15.         
  16.         System.out.println("==========排序后==========");    
  17.   
  18.         Collections.sort(dataBeans, new DemoComparator());    
  19.     
  20.         for (DataBean bean : dataBeans) {    
  21.             System.out.println(bean);    
  22.         }    
  23.     }    
  24. }    
 public class RunDemoMain {  
   
     public static void main(String[] args) {  
         List<DataBean> dataBeans = new ArrayList<DataBean>();  
         dataBeans.add(new DataBean(23, "b", "w"));  
         dataBeans.add(new DataBean(34, "e", "w"));  
         dataBeans.add(new DataBean(12, "s", "w"));  
         dataBeans.add(new DataBean(10, "c", "w"));  
 
   
         System.out.println("==========排序前==========");  
         for (DataBean bean : dataBeans) {  
             System.out.println(bean);  
         }  
       
         System.out.println("==========排序后==========");  

         Collections.sort(dataBeans, new DemoComparator());  
   
         for (DataBean bean : dataBeans) {  
             System.out.println(bean);  
         }  
     }  
 }  

参考:

http://kentkwan.iteye.com/blog/739505

http://baomw.iteye.com/blog/197905

 

 

实际项目应用:

Java代码 复制代码  收藏代码
  1. if(hotelForm.get("ascOrDesc").equals("ASC")){  
  2.                         Collections.sort(list, new MyComparator.HotelComparator());  
  3.                     }else{  
  4.                         Collections.sort(list, new MyComparator.HotelComparator());  
  5.                         Collections.reverse(list);  
  6.                     }  
if(hotelForm.get("ascOrDesc").equals("ASC")){
						Collections.sort(list, new MyComparator.HotelComparator());
					}else{
						Collections.sort(list, new MyComparator.HotelComparator());
						Collections.reverse(list);
					}
 
Java代码 复制代码  收藏代码
  1. public class MyComparator {  
  2.     public static class HotelComparator implements Comparator {  
  3.         public int compare(Object first, Object second) {  
  4.             return ((Hotel)first).getHotelNameEn().compareToIgnoreCase(((Hotel)second).getHotelNameEn());  
  5.         }  
  6.     }  
  7.   
  8. }  
public class MyComparator {
    public static class HotelComparator implements Comparator {
    	public int compare(Object first, Object second) {
    		return ((Hotel)first).getHotelNameEn().compareToIgnoreCase(((Hotel)second).getHotelNameEn());
    	}
    }

}

 ...

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值