java中 tree set_如何在Java中实现TreeSet?

我正在实现一个TreeSet,它将按照人的年龄进行排序,但如果人的名字是平等的,那么一个人将不会被保存在集合中。我实现了equals和hashcode,但是这个集合将保存所有人,即使他们有相同的名字。我不知道为什么。

public class Person implements Comparable{

private String name;

private int age;

public Person(String name, int age){

this.name = name;

this.age = age;

}

@Override

public int compareTo(Person o) {

if(this.getAge()

return -1;

}

return this.getAge() == o.getAge()?0:1;

}

@Override

public boolean equals(Object object){

return name.equals(((Person)object).getName());

}

@Override

public int hashCode(){

return name.hashCode();

}

public String getName() {

return name;

}

public int getAge() {

return age;

}

@Override

public String toString() {

return "Person [name=" + name + ", age=" + age + "]";

}

public static void main(String[] args){

Set set = new TreeSet();

set.add(new Person("Jack",30));

set.add(new Person("Jack",20));

System.out.println(set);

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值