黑马程序员技术交流社区
标题:
关于TreeSet集合排序的问题
[打印本页]
作者:
唐巍
时间:
2012-3-21 16:49
标题:
关于TreeSet集合排序的问题
TreeSet集合第一种排序方式:让元素实现Comparable接口,并覆盖其中的compareTo方法,使元素自身具备比较性。
TreeSet集合第二种排序方式:定义一个比较器,实现Comparator接口,并覆盖其中的compare方法。再将定义的比较器对象作为参数传递给TreeSet集合的构造函数。
这两种排序方式有什么不同?哪一种排序方式更好?另外,Set集合是无序的,能不能通过排序让Set集合实现元素的存入顺序与取出顺序一致?
作者:
朱辉
时间:
2012-3-21 17:19
举个例子,定义一个学生类,有姓名和年龄,如果前期编写代码是按照年龄排序用的是实现Comparable接口,并覆盖其中的compareTo方法,但是过了一段时间之后你又想按照姓名来排序,为了不更改代码,这个时候可以自己定义一个比较器实现Comparator接口,并覆盖其中的compare方法,把比较器作为参数传给TreeSet集合,如果两种比较方式都存在的情况下,以自定义比较器为先。
虽说set集合是无序的,但是TreeSet集合是按照二叉树的顺序。
可以使Set集合存入顺序和取出的顺序一致,代码如下
import java.util.Iterator;
import java.util.TreeSet;
public class TreeSetDemo {
public static void main(String[] args){
TreeSet<Person> ts = new TreeSet<Person>();
ts.add(new Person("zhangsan1",25));
ts.add(new Person("zhangsan2",22));
ts.add(new Person("zhangsan3",21));
ts.add(new Person("zhangsan4",26));
Iterator<Person> it = ts.iterator();
while(it.hasNext()){
Person p =it.next();
System.out.println(p.getName()+".."+p.getAge());
}
}
}
class Person implements Comparable
{
private String name;
private int age;
public int compareTo(Object obj){
return 1;
}
Person(String name,int age){
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
复制代码
作者:
朱辉
时间:
2012-3-21 17:19
举个例子,定义一个学生类,有姓名和年龄,如果前期编写代码是按照年龄排序用的是实现Comparable接口,并覆盖其中的compareTo方法,但是过了一段时间之后你又想按照姓名来排序,为了不更改代码,这个时候可以自己定义一个比较器实现Comparator接口,并覆盖其中的compare方法,把比较器作为参数传给TreeSet集合,如果两种比较方式都存在的情况下,以自定义比较器为先。
虽说set集合是无序的,但是TreeSet集合是按照二叉树的顺序。
可以使Set集合存入顺序和取出的顺序一致,代码如下
import java.util.Iterator;
import java.util.TreeSet;
public class TreeSetDemo {
public static void main(String[] args){
TreeSet<Person> ts = new TreeSet<Person>();
ts.add(new Person("zhangsan1",25));
ts.add(new Person("zhangsan2",22));
ts.add(new Person("zhangsan3",21));
ts.add(new Person("zhangsan4",26));
Iterator<Person> it = ts.iterator();
while(it.hasNext()){
Person p =it.next();
System.out.println(p.getName()+".."+p.getAge());
}
}
}
class Person implements Comparable
{
private String name;
private int age;
public int compareTo(Object obj){
return 1;
}
Person(String name,int age){
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
复制代码
作者:
陈汉帆
时间:
2012-3-21 17:43
Comparable & Comparator 都是用来实现集合中的排序的,只是 Comparable 是在集合内部定义的方法实现的排序,
Comparator 是在集合外部实现的排序,所以,如想实现排序,就需要在集合外定义 Comparator 接口的方法或在集合内实现 Comparable 接口的方法。
Comparable 是一个对象本身就已经支持自比较所需要实现的接口(如 String、Integer 自己就可以完成比较大小操作) 而 Comparator 是一个专用的比较器,当这个对象不支持自比较或者自比较函数不能满足你的要求时,你可以写一个比较器来完成两个对象之间大小的比较。
可以说一个是自己完成比较,一个是外部程序实现比较的差别而已。
用 Comparator 是策略模式(strategy design pattern),就是不改变对象自身,而用一个策略对象(strategy object)来改变它的行为。
比如:你想对整数采用绝对值大小来排序,Integer 是不符合要求的,你不需要去修改 Integer 类(实际上你也不能这么做)去改变它的排序行为,只要使用一个实现了 Comparator 接口的对象来实现控制它的排序就行了。
public class TestComparator {
AsComparator cl=new AsComparator();
public static void main(String[] args) {
Integer[] datas=new Integer[20];
Random rand=new Random();
for(int i=0;i<20;i++){
datas[i]=new Integer(rand.nextInt(100));
}
Arrays.sort(datas);
System.out.println(Arrays.asList(datas));
TestComparator test=new TestComparator();
Arrays.sort(datas,test.cl);
System.out.println(Arrays.asList(datas));
}
}
class AsComparator implements Comparator{
public int compare(Object o1, Object o2) {
int value1= Math.abs(((Integer)o1).intValue());
int value2=Math.abs(((Integer)o2).intValue());
return value1>value2?1:(value1==value2?0:-1);
}
}
复制代码
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2