A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 唐巍 黑马帝   /  2012-3-21 16:49  /  2534 人查看  /  3 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

TreeSet集合第一种排序方式:让元素实现Comparable接口,并覆盖其中的compareTo方法,使元素自身具备比较性。
TreeSet集合第二种排序方式:定义一个比较器,实现Comparator接口,并覆盖其中的compare方法。再将定义的比较器对象作为参数传递给TreeSet集合的构造函数。
这两种排序方式有什么不同?哪一种排序方式更好?另外,Set集合是无序的,能不能通过排序让Set集合实现元素的存入顺序与取出顺序一致?

3 个回复

倒序浏览
举个例子,定义一个学生类,有姓名和年龄,如果前期编写代码是按照年龄排序用的是实现Comparable接口,并覆盖其中的compareTo方法,但是过了一段时间之后你又想按照姓名来排序,为了不更改代码,这个时候可以自己定义一个比较器实现Comparator接口,并覆盖其中的compare方法,把比较器作为参数传给TreeSet集合,如果两种比较方式都存在的情况下,以自定义比较器为先。
虽说set集合是无序的,但是TreeSet集合是按照二叉树的顺序。
可以使Set集合存入顺序和取出的顺序一致,代码如下
  1. import java.util.Iterator;
  2. import java.util.TreeSet;

  3. public class TreeSetDemo {
  4.         public static void main(String[] args){
  5.                 TreeSet<Person> ts = new TreeSet<Person>();
  6.                 ts.add(new Person("zhangsan1",25));
  7.                 ts.add(new Person("zhangsan2",22));
  8.                 ts.add(new Person("zhangsan3",21));
  9.                 ts.add(new Person("zhangsan4",26));
  10.                
  11.                 Iterator<Person> it = ts.iterator();
  12.                 while(it.hasNext()){
  13.                         Person p =it.next();
  14.                         System.out.println(p.getName()+".."+p.getAge());
  15.                        
  16.                 }               
  17.         }
  18. }
  19. class Person  implements Comparable
  20. {
  21.         private String name;
  22.         private int age;
  23.         public int compareTo(Object obj){
  24.                 return 1;
  25.                
  26.         }
  27.         Person(String name,int age){
  28.                 this.name = name;
  29.                 this.age = age;
  30.         }
  31.         public String getName() {
  32.                 return name;
  33.         }
  34.         public void setName(String name) {
  35.                 this.name = name;
  36.         }
  37.         public int getAge() {
  38.                 return age;
  39.         }
  40.         public void setAge(int age) {
  41.                 this.age = age;
  42.         }       
  43. }
复制代码
回复 使用道具 举报
举个例子,定义一个学生类,有姓名和年龄,如果前期编写代码是按照年龄排序用的是实现Comparable接口,并覆盖其中的compareTo方法,但是过了一段时间之后你又想按照姓名来排序,为了不更改代码,这个时候可以自己定义一个比较器实现Comparator接口,并覆盖其中的compare方法,把比较器作为参数传给TreeSet集合,如果两种比较方式都存在的情况下,以自定义比较器为先。
虽说set集合是无序的,但是TreeSet集合是按照二叉树的顺序。
可以使Set集合存入顺序和取出的顺序一致,代码如下
  1. import java.util.Iterator;
  2. import java.util.TreeSet;

  3. public class TreeSetDemo {
  4.         public static void main(String[] args){
  5.                 TreeSet<Person> ts = new TreeSet<Person>();
  6.                 ts.add(new Person("zhangsan1",25));
  7.                 ts.add(new Person("zhangsan2",22));
  8.                 ts.add(new Person("zhangsan3",21));
  9.                 ts.add(new Person("zhangsan4",26));
  10.                
  11.                 Iterator<Person> it = ts.iterator();
  12.                 while(it.hasNext()){
  13.                         Person p =it.next();
  14.                         System.out.println(p.getName()+".."+p.getAge());
  15.                        
  16.                 }               
  17.         }
  18. }
  19. class Person  implements Comparable
  20. {
  21.         private String name;
  22.         private int age;
  23.         public int compareTo(Object obj){
  24.                 return 1;
  25.                
  26.         }
  27.         Person(String name,int age){
  28.                 this.name = name;
  29.                 this.age = age;
  30.         }
  31.         public String getName() {
  32.                 return name;
  33.         }
  34.         public void setName(String name) {
  35.                 this.name = name;
  36.         }
  37.         public int getAge() {
  38.                 return age;
  39.         }
  40.         public void setAge(int age) {
  41.                 this.age = age;
  42.         }       
  43. }
复制代码
回复 使用道具 举报

   Comparable & Comparator 都是用来实现集合中的排序的,只是 Comparable 是在集合内部定义的方法实现的排序,
   Comparator 是在集合外部实现的排序,所以,如想实现排序,就需要在集合外定义      Comparator 接口的方法或在集合内实现 Comparable 接口的方法。
   Comparable 是一个对象本身就已经支持自比较所需要实现的接口(如 String、Integer 自己就可以完成比较大小操作) 而 Comparator 是一个专用的比较器,当这个对象不支持自比较或者自比较函数不能满足你的要求时,你可以写一个比较器来完成两个对象之间大小的比较。

  可以说一个是自己完成比较,一个是外部程序实现比较的差别而已。
  用 Comparator 是策略模式(strategy design pattern),就是不改变对象自身,而用一个策略对象(strategy object)来改变它的行为。

  比如:你想对整数采用绝对值大小来排序,Integer 是不符合要求的,你不需要去修改 Integer 类(实际上你也不能这么做)去改变它的排序行为,只要使用一个实现了 Comparator 接口的对象来实现控制它的排序就行了。
  1. public class TestComparator {
  2.      AsComparator cl=new AsComparator();
  3.    
  4.     public static void main(String[] args) {
  5.           Integer[] datas=new Integer[20];
  6.           Random rand=new Random();
  7.          for(int i=0;i<20;i++){
  8.              datas[i]=new Integer(rand.nextInt(100));
  9.          }
  10.          Arrays.sort(datas);
  11.          System.out.println(Arrays.asList(datas));
  12.          TestComparator test=new TestComparator();
  13.          Arrays.sort(datas,test.cl);
  14.          System.out.println(Arrays.asList(datas));
  15.     }
  16. }
  17.     class AsComparator implements Comparator{

  18.         public int compare(Object o1, Object o2) {
  19.              int value1= Math.abs(((Integer)o1).intValue());
  20.              int value2=Math.abs(((Integer)o2).intValue());
  21.              return value1>value2?1:(value1==value2?0:-1);
  22.         }      
  23.     }
复制代码
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马