java treeset比较_Java中TreeSet的三种比较方法

本文介绍了Java中TreeSet的三种比较方法:1) 实现Comparable接口进行自然排序;2) 创建Comparator子类并传入构造器;3) 使用匿名内部类实现比较器。在比较时,若Comparable和Comparator并存,Comparator优先。
摘要由CSDN通过智能技术生成

今天西安鸥鹏小编为大家分享“Java中TreeSet的三种比较方法”,希望能够帮助到大家,下面就随小编一起看看Java中TreeSet的三种比较方法都是什么?

eb976f2ef1b13b87e1fee49b3d18a141.png

1、让元素具备比较性

元素自身具备比较性,需要元素实现Comparable接口,重写compareTo方法,也就是让元素自身具备比较性,这种方式叫做元素的自然排序也就做默认排序

//第一种比较方法

publicclassStudentimplementsComparable{

//publicclassStudent{

privateStringname;

privateintage;

@Override

publicintcompareTo(Objecto){

if(!(oinstanceofStudent))

thrownewRuntimeException("不是学生对象");

Students=(Student)o;

intdifferenceValue=this.age-s.age;

if(differenceValue==0)returnthis.name.compareTo(s.name);

returndifferenceValue;

}

}

2、写一个类来实现Comparator接口

当元素自身不具备比较性,或者自身具备的比较性不是所需要的。那么此时可以让容器自身具备。需要定义一个类实现接口Comparator,重写compare方法,并将该接口的子类实例对象作为参数传递给TreeMap集合的构造方法。

importjava.util.Comparator;

//第二种比较方法

publicclassComparatorLeanimplementsComparator{

@Override

publicintcompare(Objecto1,Objecto2){

Students1=(Student)o1;

Students2=(Student)o2;

intdifferenceValue=this.age-s.age;

if(differenceValue==0)returnnewInteger(s1.getName().compareTo(s2.getName()));

returndifferenceValue;

}

}

TreeSettreeSet=newTreeSet<>(newComparatorLean());

注意:当Comparable比较方式和Comparator比较方式同时存在时,以Comparator的比较方式为主;在重写compareTo或者compare方法时,必须要明确比较的主要条件相等时要比较次要条件,

3、第三种为匿名内部类方法

TreeSettreeSet=newTreeSet(newComparator(){

@Override

publicintcompare(Objecto1,Objecto2){

Students1=(Student)o1;

Students2=(Student)o2;

intnum=s1.getAge()-s2.getAge();

if(num==0)returns1.getAge()-s2.getAge();

returnnum;

}

});

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值