A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

© 途中ms前进 中级黑马   /  2015-5-27 19:01  /  628 人查看  /  1 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

TreeSet的第二种排序方式,当元素自身不具备比较性时或者具备的比较性不是需要的这时就需要让集合自身具备比较性,在集合初始化 就有了比较方式 comparator构造一个新的空TreeSet他根据指定的比较器进行排序

class student implements Comparable
{private String name;
private int age;
student(String name,int age)
{
this.name=name;
this.age=age;
}
public int compareTo(Object obj)
{if(!(obj instanceof student))
throw new RuntimeException("不是学生对象");
  student s=(student)obj;
int num=new Integer(this.getAge()).compareTo(new Integer(s.getAge()));
if(num==0)
{
return this.name.compareTo(s.name);
}
public String getName()
{
return name;
}
public int getAge()
{
return age;
}
}
class TreeSetDemo
{
public static void main(String[] args)
{
  TreeSet ts=new TreeSet();
  ts.add(new student("lisi08",20));
  ts.add(new student("lisi07 ",20));
  ts.add(new student("lisi02",22));
  ts.add(new student("lisi09",25));
  ts.add(new student("lisi007",28));
  ts.add(new student("lisi05",29));
  Iterator it=ts.iterator();
  while(it.hasNext())
  {student stu=(student)it.next();
  System.out.println(stu.getName()+"...."+stu.getAge());
   }
}
}
class myCompare implements comparator
{public int compare(Object o1,Object o2)
{Student s1=(student)o1;
Student s2=(student)o2;
int num=s.getName.compareTo(s2.getName);
if(num==0)
{
return new Integer(s1.getAge()).compareTo(new Integer(s2.getAge()));
}
}


}

1 个回复

倒序浏览
学习了,感谢分享!!!
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马