Java TreeSet定制排序-问答-阿里云开发者社区-阿里云

开发者社区> 问答> 正文

Java TreeSet定制排序

蛮大人123 2016-06-07 18:10:48 2071

我在练习TreeSet定制排序的时候。我发现在TreeSet构造函数里面定义一个Comparator的匿名内部类的实例,这个实例只需要实现compare这个方法就能运行。但是我看Comparator这个借口里面有两个方法,除了上面的那个还有一个equals。我比较好奇,内部类不需要实现接口的所有方法嘛?谢谢。下面是我的代码。

import java.util.*;
class R
{
int count;
public R(int count)
{
this.count=count;
}
public String toString(){
return "R的count的值:"+this.count;
}
public boolean equals(Object O)
{
if(O == null)
{
System.out.println("不能为空");
return false;
}
if(O instanceof R)
{
if(((R)O).count==this.count)
{
System.out.println("值相等");
return true;
}
else
{
System.out.println("值不相等");
return false;
}
}
else
{
System.out.println("类型不对");
return false;
}
}
}
public class TestTreeSet4
{
public static void main(String[] args){
TreeSet ts1 = new TreeSet(new Comparator(){
public int compare(Object O1,Object O2){
R R1=(R)O1;
R R2=(R)O2;
if(R1.count>R2.count){
return -1;
}
else if(R1.count==R2.count){
return 0;
}
else{
return 1;
}
}
});
ts1.add(new R(-2));
ts1.add(new R(-10));
ts1.add(new R(4));
System.out.println(ts1);
}
}
Java
分享到
取消 提交回答
全部回答(2)
  • idev_win
    2019-07-17 19:30:38

    您好,每一个类都继承了object 所以都有equals方法,而如果实现的接口有equals方法,则用的是父类的equals方法,不需要实现接口的equals

    0 0
  • 蛮大人123
    2019-07-17 19:30:38

    你的代码没有问题,如果需要排序的话实现的就是Comparator接口或者Comparable接口。
    那个equals方法是Object类的,你只是重写了equals方法,用来判断两个对象是否相等时可以调用equals方法,不是比较大小,而是纯粹比较是否相同。
    compareTo方法才是排序比较调用的方法,这个才是比较大小用的。

    0 0
添加回答
开发与运维
使用钉钉扫一扫加入圈子
+ 订阅

集结各类场景实战经验,助你开发运维畅行无忧

推荐文章
相似问题