简谈Comparable和Comparator区别

对于Comparable和Comparator这连个相似的接口,还是做一下比较比较好:

  Comparable Comparator
(1)只包含一个compareTo()方法,此方法可以给两个对象排序(负,0,正) 有compare()和equals()两个方法,compare()方法用来给两个参数排序(负,0,正)

(2)如果有一个Person类要实现比较

写在Person类内部:

public class Person implements Comparable{

  private int id;

  

  public int getId(){

    return id;

  }

  public int compareTo(Object o){

    return this.id - ((Person) o).getId;

  }

}


写在Person类外部,Person类不需要有任何变化

public class Person{

  private int id;

  public int getId(){

    return id;

  }

}

public class PersonComparator implements Comparator{

  public int compare(Object o1, Object o2){

    return ((Person) o1).getId - ((Person) o2).getId;

  }

}


(3)使用,personList为Person的集合对象:

Collections.sort(personList)即可进行排序


Collections.sort(personList, new PersonComparator())即可进行排序

其中Comparator使用的是设计模式中的策略模式。

时间: 2024-10-08 15:31:53

简谈Comparable和Comparator区别的相关文章

Java中Comparable和Comparator区别小结

一.Comparable简介 Comparable是排序接口.若一个类实现了Comparable接口,就意味着该类支持排序.实现了Comparable接口的类的对象的列表或数组可以通过Collections.sort或Arrays.sort进行自动排序. 此外,实现此接口的对象可以用作有序映射中的键或有序集合中的集合,无需指定比较器.该接口定义如下: package java.lang; import java.util.*; public interface Comparable<T> {

Java中Comparable和Comparator区别

一.Comparable简介 Comparable是排序接口.若一个类实现了Comparable接口,就意味着该类支持排序.实现了Comparable接口的类的对象的列表或数组可以通过Collections.sort或Arrays.sort进行自动排序. 此外,实现此接口的对象可以用作有序映射中的键或有序集合中的集合,无需指定比较器.该接口定义如下: package java.lang; import java.util.*; public interface Comparable<T> {

comparable和comparator区别

相同点:1.comparable和comparator都是用来实现treeset等根据类的自然排序进行排序的集合容器中元素之间的比较,比较算法都是由比较器自己规定不同点:1.comparable是让集合元素自身具备比较性,让元素实现comparable接口,覆盖comparaeTo(T o)方法比较此对象与指定对象的顺序.如果该对象小于.等于或大于指定对象,则分别返回负整数.零或正整数.2.comparator是让集合具备比较性,在集合初始化时就有了比较放松,定义一个类,实现compare(T

简谈ArrayList和LinkedList区别

对于ArrayList和LinkedList,他们都实现了List接口,他们的区别大致为: ArrayList LinkedList (1)底层是数组,可以以O(1)的时间复杂度对元素进行随机访问 以元素链表存储数据,每个元素和前一个以及后一个元素相连,访问的时间复杂度为O(n) (2)插入.删除慢 插入.删除快 (3)占内存少 占内存多,因为它为每个节点存储了两个引用,一个指前.一个指后

comparable 与 comparator

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

java中Comparable 和Comparator

java中Comparable 和Comparator -Comparable接口 接口定义 public interface Comparable<T> { public int compareTo(T o); } 该接口中仅仅包含了一个compareTO()函数, int compareTo(Object o): 比较当前实例对象与对象o,如果位于对象o之前,返回负值,如果两个对象在排序中位置相同,则返回0,如果位于对象o后面,则返回正值. 实例: x.compareTo(y) 来&quo

Comparable和Comparator比较实现排序 场景分析

源码分析 - Collections.sort() 一.Collection.sort使用 Collections.sort():是对一个集合进行正向排序的方法首先,传入Collections.sort()的集合的元素类型要继承Comparator<T>,这样才能保证可以比较并排序. 根据源码分析,实现方式主要有两种: (1)对普通类型和String等类型排序 (2)对JavaBean某个属性(比如时间,价格,年龄排序)进行排序 使用案例: List<String> listOne

Java中Comparable与Comparator的区别

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

Comparable和Comparator的区别

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