TreeSet的使用方法和案例详解




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


public class TreeSetDemo {


public static void main(String[] args) {
TreeSet<Person1>pts=new TreeSet<Person1>(new Comparator<Person1>() {


@Override//通过使用Comparator接口来实现比较的方法也是可以的
public int compare(Person1 o1, Person1 o2) {
if (o1.getAge()-o2.getAge()>0) {
return 1;
}else if (o1.getAge()-o2.getAge()<0) {
return -1;
}
return 0;
}
});
pts.add(new Person1("zhangsan", 15));
pts.add(new Person1("lisi", 18));
pts.add(new Person1("wangwu", 20));
pts.add(new Person1("rose", 19));
//在实现comparable接口之前输出会报错ClassCastException
System.out.println(pts);
Iterator<Person1> it=pts.iterator();
while (it.hasNext()) {
Person1 person1 = (Person1) it.next();
System.out.println(person1.getName()+">>>"+person1.getAge());
}
}


}
//通过实现Comparable接口的方法来比较,也可以不用这个方法,使用comparator
class Person1 /*implements Comparable<Person1>*/{
private String name ;
private int age;
public Person1(String name, int age) {
super();
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;
}
@Override
public String toString() {
return "Person1 [name=" + name + ", age=" + age + "]";
}
/*@Override
public int compareTo(Person1 o) {
if (this.age-o.getAge()>0) {
return 1;
}else if (this.age-o.getAge()<0) {
return  -1;
}
return 0;
}
*/
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值