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-11-06 20:30:37

Comparable和Comparator的差别的相关文章

Comparable和Comparator的区别

原文地址:http://leihuang.org/2014/11/16/Comparable-Vs-Comparator/ Comparable和Comparator都是用来实现集合中元素的比较.排序的,只是Comparable 是在集合内部定义的方法实现的排序,Comparator 是在集合外部实现的排序,所以,如想实现排序,就需要在集合外定义 Comparator 接口的方法或在集合内实现 Comparable 接口的方法. Comparator位于包java.util下,而Comparab

Comparable vs. Comparator

Comparable和Comparator是Java核心API提供的两个接口.从它们的名字,我们大致可以猜到它们用来以某种方式比较一些事物.但它们到底是什么,它们之间有又哪些差别呢?下面的两个例子回答了这个问题.这个例子用来比较HDTV的大小.阅读完下面的代码,对于如何使用Comparable和Comparator会很清楚. 1.Comparable 一个类为了能比较自身对象与其他对象实现这个接口.一个类如果要比较自己的实例就必须实现这个接口.而且要实现compareTo()这个方法.示例: c

Comparable与Comparator

转载 Comparable与Comparator的区别 (转载) Comparable & Comparator 都是用来实现集合中元素的比较.排序的,只是 Comparable 是在集合内部定义的方法实现的排序,Comparator 是在集合外部实现的排序,所以,如想实现排序,就需要在集合外定义 Comparator 接口的方法或在集合内实现 Comparable 接口的方法. Comparator位于包java.util下,而Comparable位于包 java.lang下 Comparab

Java核心API -- 7(Iterator迭代器、Comparable、Comparator比较器)

1. Iterator迭代器 所有Collection的实现类都实现了iterator方法,该方法返回一个Iterator接口类型的对象,用于实现对集合元素迭代的便利.在java.util包下. 1)Iterator定义有三个方法: ①boolean hasNext()方法:判断指针后面是否有元素. ②E next()方法:指针后移,并返回当前元素.E代表泛型,默认为Object类型. ③void remove()方法:在原集合中删除刚刚返回的元素. 2)对于List集合而言,可以通过基于下标的

Java中Comparable和Comparator实现对象比较

1.通过Comparable实现排序 package Comparable; import java.util.Arrays; public class ComparableUser implements Comparable<ComparableUser> { private String id; private int age; public ComparableUser(String id, int age) { this.id = id; this.age = age; } publi

java 数组比较,元素的比较,Comparable,Comparator比较的应用实现,排序,查找示例

java 数组比较,元素的比较,自定义Comparator的实现,排序,查找示例 package org.rui.array.compar; import java.util.Arrays; import java.util.Random; import org.rui.generics.anonymity.Generator; /** * 程序设计的基本目标是"将保持不变的事物与会发生改变的事物相分离" * 而这是,不变的是通用的排序算法,变化的是各种对象相互比较的方式, * 因此,

对象大小对比之Comparable与Comparator

一 概述 1.Comparable与Comparator使用背景 数值型数据(byte int short long float double)天生可对比大小,可排序,String实现了Comparable接口也可以对比大小与排序,而自定义类多种多样,没有一个共有的可以用作排序的指标,因此需要在自定义类中手动建立对比的方法,出于这个目的,java提供了两个接口Comparable与Comparator. 2.集合排序 Collections.sort()底层排序依靠的是Arrays.sort()

comparable 与 comparator

工作时间久了,偶尔会迷糊..... comparable 与 comparator 区别:(策略模式) 一般需要比较或者排序的类,都需要实现 comparable ,实现comparable就需要去重写 compareto方法,一般需要在这个方法里写明具体需要怎么比较,那么问题来了,如果以后类的比较方式变了的话,这个compareto方法就需要修改: 故根据策略模式,将需要比较的具体实现交给comparator接口,需要具体比较的话就实现comparator接口重写compare方法,返回int

java Comparable和Comparator

在java数组.Collection和Map的排序中,经常会用到Comparable和Comparator这两个接口. 1.Comparable 我们可以通过Arrays.sort()方法给数组排序: public static void main(String[] args) { int[] intArr={1,5,7,6,3,4}; Arrays.sort(intArr); System.out.println(Arrays.toString(intArr)); /* output: [1,