`

Comparable和Comparator接口

阅读更多

 

当需要排序的集合或数组不是单纯的数字型时,通常可以使用Comparator或Comparable,以简单的方式实现对象排序或自定义排序

Comparable是一个对象本身就已经支持自比较所需要实现的接口(如String Integer自己就可以完成比较大小操作)

而Comparator是一个专用的比较器,当这个对象不支持自比较或者自比较函数不能满足你的要求时,你可以写一个比较器来完成两个对象之间大小的比较。
    comparable是通用的接口,用户可以实现它来完成自己特定的比较,而comparator可以看成一种算法的实现,在需要容器集合collection需要比较功能的时候,来指定这个比较器,这可以看出一种设计模式  
   comparable应该比较固定,和一个具体类相绑定,而comparator比较灵活,它可以被用于各个需要比较功能的类使用。可以说前者属于“静态绑定”,而后者可以“动态绑定”。
  一个类实现了Camparable接口表明这个类的对象之间是可以相互比较的。如果用数学语言描述的话就是这个类的对象组成的集合中存在一个全序。这样,这个类对象组成的集合就可以使用Sort方法排序了。
  而Comparator的作用有两个:
  1. 如果类的设计师没有考虑到Compare的问题而没有实现Comparable接口,可以通过 Comparator来实现比较算法进行排序
  2. 为了使用不同的排序标准做准备,比如:升序、降序或其他什么序
用法:
实 现comparable类的实例就是可以排序的,重写compareTo(),只要调用sort(Object[] a)方法就可以,如果没有实现comparable接口,却调用sort(Object[] a)方法就会报错,因为sort()里面用到的mergeSort()方法将a转化成Comparable类型调用compareTo(T o)方法。
例子:
一。实现comparable接口

    import java.util.Arrays;    
    public class User implements Comparable {    
    private String id;   
    private int age;    
    public User(String id,int age) {   
        this.id = id;   
        this.age = age;   
    }    
    public int getAge() {   
        return age;   
    }    
    public void setAge(int age) {   
        this.age = age;   
    }    
    public String getId() {   
        return id;   
    }    
    public void setId(String id) {   
        this.id = id;   
    }    
    public int compareTo(Object o) {   
        return this.age - ((User) o).getAge();   
    }    
    /**  
       * 测试方法  
       */  
    public static void main(String[] args) {   
        User[] users = new User[] { new User("a", 30), new User("b", 20) };   
        Arrays.sort(users);   
        for (int i = 0; i < users.length; i++) {   
          User user = users[i];   
          System.out.println(user.getId() + " " + user.getAge());   
        }   
    }    
    }   

    二。comparator接口

    public class Person {  
    String firstname,lastname;  
    Boolean sex;  
    Integer age;  
    public Person(String firstname,String lastname,Boolean sex,Integer age) {  
        this.firstname = firstname;  
        this.lastname = lastname;  
        this.sex = sex;  
        this.age = age;  
    }  
    public String getFirstName() {  
         return firstname;  
       }  
      
       public String getLastName() {  
         return lastname;  
       }  
       public Boolean getSex() {  
          return sex;  
        }  
      
        public Integer getAge() {  
          return age;  
        }  
      
    //为了输入方便,重写了toString()  
      
    public String toString()  
        {  
          return firstname +" "+lastname+" "+(sex.booleanValue()?"男":"女")+" "+age;  
        }  
    }  
    //end person  

 下面是要实现比较器

    public class Comparators {   
    public static java.util.Comparator getComparator() {   
        return new java.util.Comparator() {   
      
          public int compare(Object o1, Object o2) {   
            if (o1 instanceof String) {   
              return compare( (String) o1, (String) o2);   
            }   
           else if (o1 instanceof Integer) {   
              return compare( (Integer) o1, (Integer) o2);   
            }   
      
           else if (o1 instanceof Person) {   
          return compare( (Person) o1, (Person) o2);   
        }   
      
            else {   
              System.err.println("未找到合适的比较器");   
              return 1;   
      
            }   
          }   
      
          public int compare(String o1, String o2) {   
            String s1 = (String) o1;   
            String s2 = (String) o2;   
            int len1 = s1.length();   
            int len2 = s2.length();   
            int n = Math.min(len1, len2);   
            char v1[] = s1.toCharArray();   
            char v2[] = s2.toCharArray();   
            int pos = 0;   
      
            while (n-- != 0) {   
              char c1 = v1[pos];   
              char c2 = v2[pos];   
              if (c1 != c2) {   
                return c1 - c2;   
              }   
              pos++;   
            }   
            return len1 - len2;   
          }   
      
          public int compare(Integer o1, Integer o2) {   
            int val1 = o1.intValue();   
            int val2 = o2.intValue();   
            return (val1 < val2 ? -1 : (val1 == val2 ? 0 : 1));   
      
          }   
          public int compare(Boolean o1, Boolean o2) {   
      
             return (o1.equals(o2)? 0 : (o1.booleanValue()==true?1:-1));   
      
           }   
      
          public int compare(Person o1, Person o2) {   
            String firstname1 = o1.getFirstName();   
            String firstname2 = o2.getFirstName();   
            String lastname1 = o1.getLastName();   
            String lastname2 = o2.getLastName();   
            Boolean sex1 = o1.getSex();   
            Boolean sex2 = o2.getSex();   
            Integer age1 = o1.getAge();   
            Integer age2 = o2.getAge();   
            return (compare(firstname1, firstname2) == 0 ?   
                    (compare(lastname1, lastname2) == 0 ? (compare(sex1, sex2) == 0 ? (compare(age1, age2) == 0 ? 0 :   
                     compare(age1, age2)) :   
                     compare(sex1, sex2)) :   
                     compare(lastname1, lastname2)) :   
                    compare(firstname1, firstname2));   
      
          }   
      
        };   
    }   
      
    }  
 

 //测试

    public class Main {   
    public Main() {   
    }   
    public static void main(String[] args) {   
        Person[] person = new Person[] {   
             new Person("ouyang", "feng", Boolean.TRUE, new Integer(27)),   
             new Person("zhuang", "gw", Boolean.TRUE, new Integer(27)),   
             new Person("zhuang", "gw", Boolean.FALSE, new Integer(27)),   
             new text.Person("zhuang", "gw", Boolean.FALSE, new Integer(2))   
         };   
         for (int i = 0; i < person.length; i++) {   
           System.out.println("before sort=" + person[i]);   
         }   
         java.util.Arrays.sort(person, Comparators.getComparator());   
        for (int i = 0; i < person.length; i++) {   
          System.out.println("after sort=" + person[i]);   
        }   
      
    }   
      
    }  
 

 另一个从网上摘的例子:

1,comparator

    import java.util.Arrays;      
    import java.util.Comparator;      
         
    public class SampleComparator implements Comparator {      
         
      public int compare(Object o1, Object o2) {      
        return toInt(o1) - toInt(o2);      
      }      
         
      private int toInt(Object o) {      
        String str = (String) o;      
        str = str.replaceAll("一", "1");      
        str = str.replaceAll("二", "2");      
        str = str.replaceAll("三", "3");      
        //       
        return Integer.parseInt(str);      
      }      
         
      /**    
       * 测试方法    
       */     
      public static void main(String[] args) {      
        String[] array = new String[] { "一二", "三", "二" };      
        Arrays.sort(array, new SampleComparator());      
        for (int i = 0; i < array.length; i++) {      
          System.out.println(array[i]);      
        }      
      }      
         
    }  
 

 2,comparable

    import java.util.Arrays;      
         
    public class User implements Comparable {      
         
      private String id;      
      private int age;      
         
      public User(String id, int age) {      
        this.id = id;      
        this.age = age;      
      }      
         
      public int getAge() {      
        return age;      
      }      
         
      public void setAge(int age) {      
        this.age = age;      
      }      
         
      public String getId() {      
        return id;      
      }      
         
      public void setId(String id) {      
        this.id = id;      
      }      
         
      public int compareTo(Object o) {      
        return this.age - ((User) o).getAge();      
      }      
         
      /**    
       * 测试方法    
       */     
      public static void main(String[] args) {      
        User[] users = new User[] { new User("a", 30), new User("b", 20) };      
        Arrays.sort(users);      
        for (int i = 0; i < users.length; i++) {      
          User user = users[i];      
          System.out.println(user.getId() + " " + user.getAge());      
        }      
      }      
         
    }    
   
    import java.util.Arrays;      
    import java.util.Comparator;      
         
    public class UserComparator implements Comparator {      
         
      public int compare(Object o1, Object o2) {      
        return ((User) o1).getAge() - ((User) o2).getAge();      
      }      
         
      /**    
       * 测试方法    
       */     
      public static void main(String[] args) {      
        User[] users = new User[] { new User("a", 30), new User("b", 20) };      
        Arrays.sort(users, new UserComparator());      
        for (int i = 0; i < users.length; i++) {      
          User user = users[i];      
          System.out.println(user.getId() + " " + user.getAge());      
        }      
      }      
         
    }    
 

 从http://hi.baidu.com/kinny/blog/item/4b3eba7e93c453380cd7da16.html 摘的一段:
1.对象本身实现Comparable接口,那么该类的实例就是可以排序的.
有关Comparable: http://blog.csdn.net/treeroot/archive/2004/09/09/99613.aspx
只要实现了Comparable接口,就可以调用Collections的sort方法对集合中的元素排序.

2.指定一个Comparator,也就是实现了Comparator的类的一个实例.
但是Java本身只提供了一个Comparator的实现,就是Collections.reverseOrder().
该方法返回的是一个已经实现了Comparable接口的反序.

看一下Comparator的全部内容:

public interface Comparator {
  int compare(Object o1, Object o2);
  boolean equals(Object obj);
}
定义了两个方法,其实我们一般都只需要实现compare方法就行了,因为类都是默认从Object继承
所以会使用Object的equals方法.
Comparator一般都作为一个匿名类出现,对于没有实现Comparable的对象的集合,排序的时候
需要指定一个Comparator.

 

分享到:
评论

相关推荐

    详解Java中Comparable和Comparator接口的区别

    主要介绍了详解Java中Comparable和Comparator接口的区别的相关资料,希望通过本文大家能彻底掌握这部分内容,需要的朋友可以参考下

    comparator接口与Comparable接口的区别

    comparator接口与Comparable接口的区别

    Comparable接口和Comparator使用示例

    通过简单的例子初步了解Comparable和Comparator的使用,注释很详细

    Java 中Comparable和Comparator区别比较

    本文,先介绍Comparable 和Comparator两个接口,以及它们的差异;接着,通过示例,对它们的使用方法进行说明

    对比Java中的Comparable排序接口和Comparator比较器接口

    Comparable和Comparator接口都可用作普通意义上对象间的比大小,但两个接口在实例化方面的用法不尽相同,接下来我们就来详细对比Java中的Comparable排序接口和Comparator比较器接口

    java中Comparable和Comparator的区别

    java.lang.Comparable和java.util.Comparator是两个容易混淆的接口,两者都带有比较的意思,那么两个接口到底有什么区别,分别在什么情况下使用呢? Comparable Comparable是java.lang包下面的接口,lang包下面可以...

    浅析Java中comparator接口与Comparable接口的区别

    本文要来详细分析一下Java中Comparable和Comparator接口的区别,两者都有比较的功能,那么究竟有什么区别呢,感兴趣的Java开发者继续看下去吧

    Java Comparable及Comparator接口区别详解

    主要介绍了Java Comparable及Comparator接口区别详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

    Java 集合方面的面试题

    什么是 Comparable 和 Comparator 接口?它们有什么区别? 如何使用 ConcurrentHashMap 类来实现线程安全的映射? 如何避免在多线程环境下对同一集合的并发修改? 如何使用 PriorityQueue 类实现一个最小堆? 如何...

    JAVA集合的使用(List、Map、Set、Queue,Collections、Comparable与Comparator,排序、搜索,内部类、equals、hashCode)

    要注意的是List,Set,Queue继承了Collection接口,Map和Collection无关,但他们都是接口,不能直接实例化对象。这里想用一个简单的例子展示一下他们的使用,内容包括:List、Map、Set、Queue,Collections、Comparable...

    Comparable接口和Comparator接口的比较

    Comparable是 排序接口。若一个类实现了Comparable接口,就意味着该类支持排序。实现了Comparable接口的类的对象的列表或数组可以通过Collections.sort或Arrays.sort进行自动排序。 此外,实现此接口的对象可以用作...

    Java中Comparator接口与Comparable接口的区别

    1. Comparator 和 Comparable 相同的地方  他们都是java的一个接口, 并且是用来对自定义的class比较大小的,  什么是自定义class: 如 public class Person{ String name; int age }.  当我们有这么一个...

    Java 比较接口comparable与comparator区别解析

    主要介绍了Java 比较接口comparable与comparator区别解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

    version4j:用于帮助比较major.minor.patch版本的库

    实现标准的Comparable和Comparator接口。用法稳定的: &lt;dependency&gt;&lt;groupId&gt;com.kcthota&lt;/groupId&gt;&lt;artifactId&gt;version4j&lt;/artifactId&gt;&lt;version&gt;4.0&lt;/version&gt;&lt;/dependency&gt;例子解析版本尝试将字符串解析为版本...

    EserciziUni:大学功课

    它涉及List,Iterable,Comparable和Comparator接口以及TreeMap,TreeSet,ArrayList,LinkedList和PriorityQueue JCF类。 它还包含类Network(网络)和类BinaryTree,类网络描述了有向网​​络,BinaryTree描述了...

    Android ComparableDemo

    Comparable是在集合内部定义的方法实现的排序,而Comparator是在集合外部实现的排序,如果想实现排序,就需要在集合外定义Comparator接口的方法或在集合内实现Comparable接口的方法。 这里是一个简单的...

    Android ComparatorDemo

    Comparable是在集合内部定义的方法实现的排序,而Comparator是在集合外部实现的排序,如果想实现排序,就需要在集合外定义Comparator接口的方法或在集合内实现Comparable接口的方法。 这里是一个简单的...

    java Compare示例

    这是java的comparable接口和comparator接口的例子

    ComparaTest.rar

    用Java的Comparable接口与Comparator接口分别实现类的比较排序~~

Global site tag (gtag.js) - Google Analytics