黑马程序员技术交流社区

标题: 这段程序没看懂,请大家帮忙看下 [打印本页]

作者: qmlovewhr    时间: 2013-7-5 14:45
标题: 这段程序没看懂,请大家帮忙看下
本帖最后由 赵海洋 于 2013-7-6 18:16 编辑

import java.util.*;
class TreeSetDemo
{
public static void main(String[] args)
{
  TreeSet ts=new TreeSet();
  ts.add(new Student("lisi01",22));
  ts.add(new Student("lisi02",20));
  ts.add(new Student("lisi04",19));
  ts.add(new Student("lisi03",19));
  Iterator it=ts.iterator();
  while(it.hasNext())
  {
   Student stu=(Student)it.next();
   System.out.println(stu.getName()+"..."+stu.getAge());
  }
}
}
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;
  System.out.println(this.name+"......compareTo......"+s.name);
  if(this.age>s.age)
   return 1;
  if(this.age==s.age)
  {
   return this.name.compareTo(s.name);
  }
   return -1;
}
public String getName()
{
  return this.name;
}
public int getAge()
{
  return this.age;
}
}
这段程序中的compateTo方法没太看明白,你们说TreeSet是自动调用compartTo方法的哈,this.name应该指调用TreeSet添加对象一进来的名字,可是s.name指的是在这之前添加的对象的名字,也没有循环结构,也没有多次调用,它怎么就能逐个去进行比较?Student stu=(Student)it.next();另外这是一个强制类型转制吧,它把it.next()取出来的对象强制转成Student类的对象吧,这样理解没错吧?求大家给个更容易理解的方式。

作者: 哪颗最亮的星星    时间: 2013-7-5 15:11
首先:基于 TreeMap 的 NavigableSet 实现。使用元素的自然顺序对元素进行排序,或者根据创建 set 时提供的 Comparator 进行排序,具体取决于使用的构造方法。

学生类实现了Comparable接口,这样它就具备了可比较性,当把对象添加到集合的时候,集合会调用你定你的CompareTo方法。当学生类不具备可比较性的时候,集合会按照自然排序对元素进行排序。




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2