Java中的排序 Comparator,Comparable

导读:
  要实现排序功能,一般有两种途径,这里对基本类型不适用,基本类型一般有Arrays中的静态方法.
  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.
  这里举例说明
  对于实现了Comparable的类我们就用最简单的Integer
  List list=new ArrayList();
  list.add(new Integer(3));
  list.add(new Integer(53));
  list.add(new Integer(34));
  Collections.sort(list);
  对于没有实现Comparable的,我们就用Object,按照hashCode大小来排序.
  List list= new ArrayList();
  list.add(new Object());
  list.add(new Object());
  list.add(new Object());
  Collections.sort(list,new Comparator(){ public int compare(Object o1, Object o2){
  return (o1.hashCode()-o2.hashCode());
  })
  =========================================================================
  Comparator,Comparable接口区别
  最近在做一个对象排序的功能,需要按不同规则排序.看了Arrays,Collections,的sort方法,
  了解了Comparator,Comparable两个接口,找到了适用于自己的排序办法,下面把自己的
  理解和收集到的我认为很经典的解释整理如下:
  comparable是通用的接口,用户可以实现它来完成自己特定的比较,而comparator可以看成一种算法的实现,在需要容器集合collection需要比较功能的时候,来指定这个比较器,这可以看出一种设计模式,将算法和数据分离,就像C++ STL中的函数对象一样。
  前者应该比较固定,和一个具体类相绑定,而后者比较灵活,它可以被用于各个需要比较功能的类使用。可以说前者属于“静态绑定”,而后者可以“动态绑定”。
  一个类实现了Camparable接口表明这个类的对象之间是可以相互比较的。如果用数学语言描述的话就是这个类的对象组成的集合中存在一个全序。这样,这个类对象组成的集合就可以使用Sort方法排序了。
  而Comparator的作用有两个:
  1. 如果类的设计师没有考虑到Compare的问题而没有实现Comparable接口,可以通过 Comparator来实现比较算法进行排序
  2. 为了使用不同的排序标准做准备,比如:升序、降序或其他什么序

本文转自
http://hi.baidu.com/kinny/blog/item/4b3eba7e93c453380cd7da16.html
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值