黑马程序员技术交流社区

标题: 这两个接口有什么区别? [打印本页]

作者: wodeairenw    时间: 2013-3-12 19:53
标题: 这两个接口有什么区别?
接口Comparator和接口Comparable有什么区别?一般是怎么区别使用它们的?看视频有点模糊了。

作者: 彭颖    时间: 2013-3-12 21:05
Comparator和Comparable的区别

先看一下使用Comparator对User集合实现排序的方式:

  1. import java.util.Arrays;  
  2. import java.util.Comparator;  
  3.   
  4. public class UserComparator implements Comparator {  
  5.   
  6.   public int compare(Object o1, Object o2) {  
  7.     return ((User) o1).getAge() - ((User) o2).getAge();  
  8.   }  
  9.   
  10.   /**
  11.    * 测试方法
  12.    */  
  13.   public static void main(String[] args) {  
  14.     User[] users = new User[] { new User("a", 30), new User("b", 20) };  
  15.     Arrays.sort(users, new UserComparator());  
  16.     for (int i = 0; i < users.length; i++) {  
  17.       User user = users[i];  
  18.       System.out.println(user.getId() + " " + user.getAge());  
  19.     }  
  20.   }  
  21.   
  22. }  
复制代码
一个类实现了Camparable接口则表明这个类的对象之间是可以相互比较的,这个类对象组成的集合就可以直接使用sort方法排序。
Comparator可以看成一种算法的实现,将算法和数据分离,Comparator也可以在下面两种环境下使用:
1、类的设计师没有考虑到比较问题而没有实现Comparable,可以通过Comparator来实现排序而不必改变对象本身
2、可以使用多种排序标准,比如升序、降序等
作者: HM刘俊    时间: 2013-3-12 21:11
你这里的接口Comparator和接口Comparable里面具体什么内容啊???
这只是两个接口名而已。就好比类名一样,具体要看里面都包含哪些内容。
其实,从某种程度上,接口与类十分相似。
只是抽象化了点。
作者: HM王琦    时间: 2013-3-12 21:14
TreeSet:底层数据结构是二叉树,能对Set集合进行排序。
   保证元素唯一性的依据是:compartTo()返回0
   TreeSet排序的第一种方式:让元素自身具备比较性。
    元素需要实现Comparable接口,覆盖compareTo方法。
    这种方式也称为为元素的自然顺序,或者叫做默认顺序。
   TreeSet的第二种排序方式。
    当元素自身不具备比较性时,或者具备的比较性不是所需要的。
    这时就需要让集合自身具备比较性。
    在集合初始化时,就有了比较方式。
    方法:自定义比较器,将比较器作为参数传递给集合的构造函数
          实现Compartor接口,复写compare()方法,返回值为0说明元素相同。

可以看我的博客:http://www.cnblogs.com/wqstu/archive/2013/03/03/2941180.html
作者: 郑昌奋    时间: 2013-3-12 21:20
她们两个都是用来实现集合中的排序的,Comparable是一个对象本身就已经支持自比较所需要实现的接口(如String    Integer自己就可以完成比较大小操作)          而Comparator是一个专用的比较器,当这个对象不支持自比较或者自比较函数不能满足你的要求时,你可以写一个比较器来完成两个对象之间大小的比较。也就是有些对象没有比较性的时候就可以用Comparator来实现接口。再复写里面的compare()方法
作者: Benwolf0818    时间: 2013-3-12 21:29
comparable 和  Comparator 都是用来实现集合中的排序的
只是Comparable是在集合内部定义的方法实现的排序
Comparator是在集合外部实现的排序

所以,如想实现排序,就需要在集合外定义Comparator接口的方法compare()或在集合内实现Comparable接口的方法compareTo()

Comparable是一个对象本身就已经支持自比较所需要实现的接口(如String    Integer自己就可以完成比较大小操作)   
   
而Comparator是一个专用的比较器,当这个对象不支持自比较或者自比较函数不能满足你的要求时,你可以写一个比较器来完成两个对象之间大小的比较。




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2