TreeSet集合排序两种实现方式Comparable和Comparator比较

http://blog.csdn.net/geek_ymv/article/details/38147047


import java.util.Comparator;
import java.util.Iterator;
import java.util.TreeSet;

/**
 * TreeSet集合排序有两种方式,Comparable和Comparator区别:
 * 1:让元素自身具备比较性,需要元素对象实现Comparable接口,覆盖compareTo方法。
 * 2:让集合自身具备比较性,需要定义一个实现了Comparator接口的比较器,并覆盖compare方法,
 *   并将该类对象作为实际参数传递给TreeSet集合的构造函数。 第二种方式较为灵活。
 */
public class TreeSetDemo3 {
    public static void main(String[] args) {

        Teacher t1 = new Teacher(111L);
        Teacher t2 = new Teacher(222L);

        TreeSet<Teacher> teachers = new TreeSet<Teacher>();
        teachers.add(t1);
        teachers.add(t2);

        for (Iterator<Teacher> iter = teachers.iterator(); iter.hasNext();) {
            Teacher t =  iter.next();
            System.out.println(t.getId());
        }

        System.out.println("------------------------");

        Student s1 = new Student(123L);
        Student s2 = new Student(456L);                 //让集合自身具备比较性,这种方式较灵活    
        TreeSet<Student> students = new TreeSet<Student>(new StudentComparator());  

        students.add(s1);
        students.add(s2);

        for (Iterator<Student> iter = students.iterator(); iter.hasNext();) {
            Student s = iter.next();
            System.out.println(s.getId());
        }

    }
}

/**
 * 采用实现Comparable接口重写compareTo方法的方式,让元素自身具备比较性
 * @author Administrator
 *
 */
class Teacher implements Comparable<Teacher>{
    private Long id;

    public Teacher() {
    }
    public Teacher(Long id) {
        this.id = id;
    }

    public Long getId() {
        return id;
    }
    public void setId(Long id) {
        this.id = id;
    }

    @Override
    public int compareTo(Teacher o) {
        return (int) (this.id - o.getId());
    }
}

//学生类
class Student {

    private Long id;

    public Student() {
    }
    public Student(Long id) {
        this.id = id;
    }

    public Long getId() {
        return id;
    }
    public void setId(Long id) {
        this.id = id;
    }
}

/**
 * 自定义定义一个实现了Comparator接口的比较器,并覆盖compare方法
 */
class StudentComparator implements Comparator<Student> {
    @Override
    public int compare(Student o1, Student o2) {
        return (int) (o1.getId() - o2.getId()); // 根据升序排序
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值