Comparable和Comparator的区别

原文地址:http://leihuang.org/2014/11/16/Comparable-Vs-Comparator/

Comparable和Comparator都是用来实现集合中元素的比较、排序的,只是Comparable 是在集合内部定义的方法实现的排序,Comparator 是在集合外部实现的排序,所以,如想实现排序,就需要在集合外定义 Comparator 接口的方法或在集合内实现 Comparable 接口的方法。

Comparator位于包java.util下,而Comparable位于包 java.lang下.

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

自定义的类要在加入list容器中后能够排序,可以实现Comparable接口,在用Collections类的sort方法排序时,如果不指定Comparator,那么就以自然顺序排序,如API所说:

Sorts the specified list into ascending order, according to the natural ordering of its elements. All elements in the list must implement the Comparable interface

这里的自然顺序就是实现Comparable接口设定的排序方式。

而 Comparator 是一个专用的比较器,当这个对象不支持自比较或者自比较函数不能满足你的要求时,你可以写一个比较器来完成两个对象之间大小的比较。

可以说一个是自已完成比较,一个是外部程序实现比较的差别而已。

用 Comparator 是策略模式(strategy design pattern),就是不改变对象自身,而用一个策略对象(strategy object)来改变它的行为。

Comparable interface

例如我们定义一个类Country,我们希望他的对象有大小关系,且依据countryId来排序的,所以我们让Country实现Comparable接口,使其具备大小关系的能力,代码如下:

class Country implements Comparable{
    private int countryId ;
    @Override
    public int compareTo(Object o) {
        Country country = (Country)o ;
        return this.getCountryId()>country.getCountryId()?1:this.getCountryId()==
                country.getCountryId()?0:-1 ;
    }
}

此时Country就具备了比较的能力了,如同Integer,String类一样,此时Country对象的集合就可以通过Collections.sort(),或者Arrays.sort(),来进行排序了。

下面我们来看看Comparator使如何实现的。

Comparator interface

就像我们之前说的一样,Comparator其实就好像一个工具,它不是使得Country具有排序性,而是他不改变Country类本身,而是单独实现一个排序工具,来提供给Country用,下面我们就来实现这个排序工具类。

class Country{
    private int id ;
    public Country(int id){
        this.id = id ;
    }
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
}
class CountryByIdComparator implements Comparator<Country>{
    @Override
    public int compare(Country o1, Country o2) {
        return o1.getId()>o2.getId()?1:o1.getId()==o2.getId()?0:-1 ;
    }
}

大家注意到没,单单看Country类,其实并没有跟比较有任何关系,但是它却能通过实现Comparator借口的工具类ContryByIdComparator来实现自动排序。此时调用的Collections.sort()就需要两个参数了,一个是集合,一个是实现Comparator接口的工具类。

我们也可以利用匿名内部类来实现,而不需要单独定义ContryByIdComparator这样一个工具类,代码如下:

Collections.sort(cityList,new Comparator<City>(){
            @Override
            public int compare(City o1, City o2) {
                return o1.getId()>o2.getId()?1:o1.getId()==o2.getId()?0:-1 ;
            }

        }) ;

Comparator 是策略模式(strategy design pattern),就是不改变对象自身,而用一个策略对象(strategy object)来改变它的行为。

下面这张图就是它们两的区别:

Refference

  1. Comparable与Comparator的区别
  2. Difference between Comparator and Comparable in Java


2014-11-16 17:27:25

Brave,Happy,Thanksgiving !

时间: 2024-10-11 17:02:11

Comparable和Comparator的区别的相关文章

Java中Comparable和Comparator接口区别分析

Java中Comparable和Comparator接口区别分析 来源:码农网 | 时间:2015-03-16 10:25:20 | 阅读数:8902 [导读] 本文要来详细分析一下Java中Comparable和Comparator接口的区别,两者都有比较的功能,那么究竟有什么区别呢,感兴趣的Java开发者继续看下去吧.Comparable 简介Comparable 是排序接口.若一个类实现了Comparab 本文要来详细分析一下Java中Comparable和Comparator接口的区别,

Java 解惑:Comparable 和 Comparator 的区别

读完本文你将了解到: Comparable 自然排序 Comparator 定制排序 总结 Java 中为我们提供了两种比较机制:Comparable 和 Comparator,他们之间有什么区别呢?今天来了解一下. Comparable 自然排序 Comparable 在 java.lang 包下,是一个接口,内部只有一个方法 compareTo(): public interface Comparable<T> { public int compareTo(T o); } Comparab

【Java基础】接口Comparable和Comparator的区别和关系

接口Comparable和Comparator的区别和关系 1).两者都是实现集合中元素的比较.排序: 2).Comparable是集合内部定义方法实现排序,Comparator是集合外部实现排序 3).Comparator接口在java.util下,Comparable接口在java.lang下; 通常自定义类加入如List等容器中能够排序,可以实现Comparable接口,在用Collections.sort(List<T> list, Comparator<? super T>

Java中Comparable与Comparator的区别

相同 Comparable和Comparator都是用来实现对象的比较.排序 要想对象比较.排序,都需要实现Comparable或Comparator接口 Comparable和Comparator都是Java的接口 区别 Comparator位于java.util包下,而Comparable位于java.lang包下 Comparable接口的实现是在类的内部(如 String.Integer已经实现了Comparable接口,自己就可以完成比较大小操作),Comparator接口的实现是在类

【转】:浅析 Comparable和 Comparator的区别

简介Comparable和 Comparator都是java.util包下的两个接口,从字面上看这两个接口都是用来做比较用的,但是jdk里面不可能定义两个功能相同的接口,所以他们肯定有不同的用处. 1.Comparable1.1 说明Comparable可以认为是一个内比较器,实现了Comparable接口的类有一个特点,就是这些 类是可以和自己比较的,至于具体和另一个实现了Comparable接口的类如何比较,则依赖compareTo方法的实现,compareTo方法也被称为自然比较方法.如果

Comparable和Comparator的区别?

一个类实现了Camparable接口则表明这个类的对象之间是可以相互比较的,这个类对象组成的集合就可以直接使用sort方法排序. Comparator可以看成一种算法的实现,将算法和数据分离,Comparator也可以在下面两种环境下使用: 1.类的没有考虑到比较问题而没有实现Comparable,可以通过Comparator来实现排序而不必改变对象本身 2.可以使用多种排序标准,比如升序.降序等 Comparable & Comparator 都是用来实现集合中元素的比较.排序的,只是 Com

Comparable与Comparator的区别

Comparable & Comparator 都是用来实现集合中元素的比较.排序的,只是 Comparable 是在集合内部定义的方法实现的排序,Comparator 是在集合外部实现的排序,所以,如想实现排序,就需要在集合外定义 Comparator 接口的方法或在集合内实现 Comparable 接口的方法. Comparator位于包java.util下,而Comparable位于包   java.lang下 Comparable 是一个对象本身就已经支持自比较所需要实现的接口(如 St

Java学习之Comparable与Comparator的区别

Comparable & Comparator 都是用来实现集合中元素的比较.排序的,只是 Comparable 是在集合内部定义的方法实现的排序,Comparator 是在集合外部实现的排序,所以,如想实现排序,就需要在集合外定义 Comparator 接口的方法或在集合内实现 Comparable 接口的方法.Comparator位于包java.util下,而Comparable位于包   java.lang下Comparable 是一个对象本身就已经支持自比较所需要实现的接口(如 Stri

Comparable 与 Comparator的区别

Comparable & Comparator 都是用来实现集合中元素的比较.排序的,只是 Comparable 是在集合内部定义的方法实现的排序,Comparator 是在集合外部实现的排序,所以,如想实现排序,就需要在集合外定义 Comparator 接口的方法或在集合内实现 Comparable 接口的方法. Comparator位于包java.util下,而Comparable位于包 java.lang下 Comparable 是一个对象本身就已经支持自比较所需要实现的接口(如 Stri